V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
MySQL 5.5 Community Server
MySQL 5.6 Community Server
Percona Configuration Wizard
XtraBackup 搭建主从复制
Great Sites on MySQL
Percona
MySQL Performance Blog
Severalnines
推荐管理工具
Sequel Pro
phpMyAdmin
推荐书目
MySQL Cookbook
MySQL 相关项目
MariaDB
Drizzle
参考文档
http://mysql-python.sourceforge.net/MySQLdb.html
daimaosix
V2EX  ›  MySQL

我这个批量替换某表字段内容的 SQL 语句有错吗...一直报错 1064

  •  
  •   daimaosix · 2020-08-15 15:34:51 +08:00 · 2488 次点击
    这是一个创建于 1568 天前的主题,其中的信息可能已经有所发展或是发生改变。

    数据库版本 MariaDB-10.4.10 ,刚在执行一个批量替换某表字段内容的语句,但检查和调整了很久始终报错 1064,麻烦 V 友给看一下到底是哪里错了...

    update base_info set main_url = replace(main_url,'v02-vid.xxxx.com','v01-vid.xxxx.myxxxx.com');
    

    报错如下

    ERROR 1064 (42000): You have an error in your SQL syntax; check the manual that corresponds to your MariaDB server version for the right syntax to use near 'update base_info set main_url = replace(main_url,'v02-vid' at line 1
    
    第 1 条附言  ·  2020-08-15 17:24:40 +08:00
    问题应该是#10 楼老哥说的,有不可见符号,已经从头到尾重新手打了一遍,正常执行了,谢谢大家。
    14 条回复    2020-08-15 21:05:55 +08:00
    wangsongyan
        1
    wangsongyan  
       2020-08-15 15:41:50 +08:00 via iPhone
    命令行执行,还是代码调用?
    starwing
        2
    starwing  
       2020-08-15 15:55:26 +08:00
    试试看是不是 main_url 这玩意儿不在表里,我拿了个错误的字段试了下报你的这个错。
    daimaosix
        3
    daimaosix  
    OP
       2020-08-15 15:59:31 +08:00
    @wangsongyan 直接命令行执行的
    daimaosix
        4
    daimaosix  
    OP
       2020-08-15 16:00:01 +08:00
    @starwing 在呢,我反复确认了好几遍,实在找不到问题了
    hm20062006ok
        5
    hm20062006ok  
       2020-08-15 16:19:04 +08:00
    加上 where 语句试试?可能是安全策略设置保守?
    akira
        6
    akira  
       2020-08-15 16:22:54 +08:00
    命令行?库名错了吧
    daimaosix
        7
    daimaosix  
    OP
       2020-08-15 16:30:13 +08:00
    @hm20062006ok 没有做安全策略,这个就是一个普通的集群,没做太多策略,打算下个月换云数据库了
    daimaosix
        8
    daimaosix  
    OP
       2020-08-15 16:32:09 +08:00
    @akira 没错的,我进入那个库执行的,表和字段名都没错,就是不知道哪里错了,难受
    goodboy95
        9
    goodboy95  
       2020-08-15 17:06:00 +08:00
    错误位置在整个语句之前,这就有点怪异。
    总感觉是哪里有问题,导致传给数据库的语句不止这么一句。
    goodboy95
        10
    goodboy95  
       2020-08-15 17:07:02 +08:00   ❤️ 1
    这语句是手打的吗?不是的话建议从头手打一遍,排除不可见符号导致的问题。
    zhangysh1995
        11
    zhangysh1995  
       2020-08-15 17:12:53 +08:00
    看起来没毛病,可以到 MariaDB 社区或者 MySQL Slack 问一下。觉得可能是 SQL Parser 有 bug 。。。
    daimaosix
        12
    daimaosix  
    OP
       2020-08-15 17:15:12 +08:00
    @goodboy95 我是先在 VScode 手动打的,确认 OK 了,复制到命令行执行的,我现在试试在命令行输入试试
    laminux29
        13
    laminux29  
       2020-08-15 18:48:15 +08:00
    我最烦这种一行代码包含多个操作的做法,不易读,也不利于调试,而且,连自己也被坑了。
    daimaosix
        14
    daimaosix  
    OP
       2020-08-15 21:05:55 +08:00
    @laminux29 同感
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2621 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 23ms · UTC 07:16 · PVG 15:16 · LAX 23:16 · JFK 02:16
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.