单引号,以及行尾的斜杠引起的困惑:

这一次的问题,我们直接从实际的工作中说起:

工作内容简介: 有一批用户ID存在文件里,需要从数据库里删除?

做这个事情,可能有很多的方法:

1, 把ID导入到数据库中,用SQL直接做表关联去删除 ;

2, 用SHELL(或其他语言)写个小程序,根据文件里的ID做一个FOR 循环,然后在MYSQL中去删除 ;

3, 用sed直接把ID转成delete语句,完了直接运行即可;[@more@]

由于数据量较大(1.6亿),显然,我会用偷懒以及简单的方法3 :

----------------------------------------------

[root@im_ctuallot1 tmp]# cat loginid.txt

xouqun76818

ogku15mtb7c

jinlongkaikai@163.com

曾朴绍283902

轻舞飞扬061129付了

[root@im_ctuallot1 tmp]# sed -e "s/^/delete from ctulog.db_allot_center_64 where long_id='/g" -e "s/$/';/g" loginid.txt > loginid.sql

[root@im_ctuallot1 tmp]# cat loginid.sql

delete from ctulog.db_allot_center_64 where long_id='xouqun76818';

delete from ctulog.db_allot_center_64 where long_id='ogku15mtb7c';

delete from ctulog.db_allot_center_64 where long_id='jinlongkaikai@163.com';

delete from ctulog.db_allot_center_64 where long_id='曾朴绍283902';

delete from ctulog.db_allot_center_64 where long_id='轻舞飞扬061129付了';

mysql -uroot -h127.0.0.1 --default-character-set=latin1 --force ctulogdb < loginid.sql

--force 是防止某个SQL出现错误,而导致整个任务终止;

---------------------------------------------

搞定。

这看似非常简单的方法,也暴露出很多的问题,结果1.6行数据只成功删除了3300W,任务失败;

其实是我把这个任务想得太简单了: 在用户ID中存在任何可能的字符 ,如:

bao'pijkl

tingting831118

注意,在用户ID中有" ' ", 在行末尾有:" ";

我们把这样的语句渗杂到其他ID中,我们看会有怎么的效果;

[root@im_ctuallot1 tmp]# cat loginid.txt

xouqun76818

bao'pijkl

ogku15mtb7c

jinlongkaikai@163.com

曾朴绍283902

tingting831118

轻舞飞扬061129付了

[root@im_ctuallot1 tmp]# sed -e "s/^/delete from ctulog.db_allot_center_64 where long_id='/g" -e "s/$/';/g" loginid.txt > loginid.sql

[root@im_ctuallot1 tmp]# cat loginid.sql

delete from ctulog.db_allot_center_64 where long_id='xouqun76818';

delete from ctulog.db_allot_center_64 where long_id='bao'pijkl';

delete from ctulog.db_allot_center_64 where long_id='ogku15mtb7c';

delete from ctulog.db_allot_center_64 where long_id='jinlongkaikai@163.com';

delete from ctulog.db_allot_center_64 where long_id='曾朴绍283902';

delete from ctulog.db_allot_center_64 where long_id='tingting831118';

delete from ctulog.db_allot_center_64 where long_id='轻舞飞扬061129付了';

[root@im_ctuallot1 tmp]# mysql -uroot -h127.0.0.1 --default-character-set=latin1 --force ctulog < loginid.sql

ERROR at line 2: Unknown command '''.

ERROR 1064 (42000) at line 2: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'pijkl';

delete from ctulog.db_allot_center_64 where long_id='ogku15mtb7c';

delet' at line 1

会出现一堆这样的错误;

如果你手动把以上SQL贴到MYSQL中去执行:

root@127.0.0.1 : ctulog 15:59:04>

root@127.0.0.1 : ctulog 15:59:04> delete from ctulog.db_allot_center_64 where long_id='xouqun76818';

Query OK, 0 rows affected (0.00 sec)

root@127.0.0.1 : ctulog 15:59:05> delete from ctulog.db_allot_center_64 where long_id='bao'pijkl';

'> delete from ctulog.db_allot_center_64 where long_id='ogku15mtb7c';

'> delete from ctulog.db_allot_center_64 where long_id='jinlongkaikai@163.com';

'> delete from ctulog.db_allot_center_64 where long_id='曾朴绍283902';

'> delete from ctulog.db_allot_center_64 where long_id='tingting831118';

ERROR:

Unknown command '''.

ERROR 1064 (42000): You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'pijkl';

delete from ctulog.db_allot_center_64 where long_id='ogku15mtb7c';

delet' at line 1

root@127.0.0.1 : ctulog 15:59:05> delete from ctulog.db_allot_center_64 where long_id='轻舞飞扬061129付了';

Query OK, 0 rows affected (0.00 sec)

root@127.0.0.1 : ctulog 15:59:10>

只有第一条,最后一条执行成功了;

到这里我想大家应该明白了,

最关键的是单引号的不匹配导致MYSQL不能正确认识完整的SQL;

注意,在用户ID中,出现 单个单引号,或以""结束,都会有这个问题;

问题找到了,其实解决很简单,就是先把用户ID中的单引号和"$"作一个转换:

[root@im_ctuallot1 tmp]# cat loginid.txt

xouqun76818

bao'pijkl

ogku15mtb7c

jinlongkaikai@163.com

曾朴绍283902

tingting831118

轻舞飞扬061129付了

[root@im_ctuallot1 tmp]# sed -e "s///g" -e "s/'/'/g" -e "s/^/delete from ctulog.db_allot_center_64 where long_id='/g" -e "s/$/';/g" loginid.txt > loginid.sql

[root@im_ctuallot1 tmp]# cat loginid.sql

delete from ctulog.db_allot_center_64 where long_id='xouqun76818';

delete from ctulog.db_allot_center_64 where long_id='bao'pijkl';

delete from ctulog.db_allot_center_64 where long_id='ogku15mtb7c';

delete from ctulog.db_allot_center_64 where long_id='jinlongkaikai@163.com';

delete from ctulog.db_allot_center_64 where long_id='曾朴绍283902';

delete from ctulog.db_allot_center_64 where long_id='tingting831118';

delete from ctulog.db_allot_center_64 where long_id='轻舞飞扬061129付了';

[root@im_ctuallot1 tmp]#

是这样的SQL执行就不会有任何问题。

就这么简单的问题,耗了5个小时,还是SHARE一下以免大家在这里浪费时间;

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/703656/viewspace-1036578/,如需转载,请注明出处,否则将追究法律责任。

mysql跳脱字符 单引号_MYSQL特殊字符(单引号,行尾斜杠)的处理相关推荐

  1. mysql 反斜杠 转义_MySQL中执行sql语句反斜杠需要进行转义

    最近在执行一个sql备份的还原后,发现系统的部分路径找不到,于是开始debug,最后发现,是由于备份的sql语句在还原时,反斜杠(\)被mysql吃掉了.本文对反斜杠和顺斜杠进行了测试,并给出了解决方 ...

  2. vim, vi光标跳转到文首/文末/行首/行尾

    若在Insert模式下,需要先按一下Esc, 文首:按G(区分大小写) 文末:按gg(区分大小写) (跳转到行首和行尾,各有两种方法:) 行首:①按Home ②按0(数字0) 行尾:①按End ②按$ ...

  3. mysql如何修改学生表_MySQL 详细单表增删改查crud语句

    MySQL 增删改查语句 1.创建练习表 这里练习表没有满足三范式 第一范式(又称 1NF):保证每列的原子性 数据表中的每一列(字段),必须是不可拆分的最小单元,也就是确保每一列的原子性.满足第一范 ...

  4. mysql左连接去重查询_mysql之单表查询、多表查询

    mysql查询 单表查询 """ 增: insert [into] [数据库名.]表名[(字段1[,...,字段n])] values (数据1[,...,数据n])[, ...

  5. mysql 联合索引 单个索引_mysql的单例索引和联合索引

    --联合索引查询第一个.第二个参数(走索引) explain select* from emp where ENAME = 'wang' and JOB 单例索引:在数据库的单例上建立的索引. 联合索 ...

  6. mysql表单查询_MySQL表单集合查询

    表单查询 简单查询 SELECT语句 查询所有字段 指定所有字段:select 字段名1,字段名2,...from 表名; select * from 表名; 查询指定字段 select 字段名1,字 ...

  7. mysql 多表联合视图_MySQL之单表、多表查询、连接、视图

    select 查询类型:单表查询.多表查询,子查询 select * from tb_name; 查询表中所有字段 select field1,field2 from tb_name; 投影,只显示每 ...

  8. mysql 主从单表_MySQL主从复制单表或者多表

    MySQL数据库安装不过多的介绍了:必须保证2个数据库的版本一致. 主数据库:192.168.0.43 从数据库:192.168.0.53 修改43主数据库的配置文件: 打开logbin日志生成文件: ...

  9. mysql单源多表同步单库单表_MySQL主从复制单表或者多表

    MySQL数据库安装不过多的介绍了:必须保证2个数据库的版本一致. 主数据库:192.168.0.43 从数据库:192.168.0.53 修改43主数据 MySQL数据库安装不过多的介绍了:必须保证 ...

最新文章

  1. h3c wa2620胖ap设置_AP考试|错过报名不用慌,香港考区目前仍然可以报名!
  2. python中的chr和ord函数_python chr()和ord() | 学步园
  3. 走好达叔!每年“癌症”新增400万例,数据分析揭示“癌症”到底有多可怕
  4. php2个栈写一个队列,【数据结构】栈面试题--两个栈实现一个队列
  5. RED HAT 7 性能监控工具
  6. mysql truncate 授权_Oracle给用户授权truncatetable的实现方案
  7. winform中ShowInTaskbar设为false时,注册的热键失效的问题解决
  8. 超详细java中的ClassLoader详解
  9. 19年Q2了,运维的你有啥计划吗?
  10. Android系统开机优化
  11. 2021-10-22 学习笔记:和弦对照信息表
  12. 笔记本出现此windows无线服务器,笔记本Windows7提示Windows无法配置此无线连接如何解决?...
  13. python-decouple简介
  14. 习题——路由与交换机技术(五)
  15. 【保姆级】包体积优化教程
  16. Laravel中使用webhook开发Telegram机器人自定义指令
  17. android获取系统资源文件,Android 系统文件获取
  18. mysql数据库应用题库_MySQL数据库设计与应用题库免费期末考试2021答案
  19. 虹科小课堂|密度测量,你了解多少?
  20. 《Deep Learning for Computer Vision withPython》阅读笔记-StarterBundle(第4 - 5章)

热门文章

  1. 通过Cookie存取用户游览记录的代码示例
  2. Android:使用SharedPreferences进行数据存储
  3. 浅谈mtk平台手机通过gprs网络连接pc
  4. android ndk配置环境,在Windows中的安装Android NDK开发环境
  5. linux oracle异常,Linux上oracle常见安装异常总结
  6. python画彩色螺旋线_Python turtle 绘制彩色螺旋线
  7. 洛谷——P1010 [NOIP1998 普及组] 幂次方
  8. 实测解决:SpringBoot 中 Invalid character found in the request target 异常
  9. Navicat连接MySQL8.0版本时出现Client does not support authentication protocol requested by server;报错的问题解决办法
  10. 文本属性之装饰文本(CSS、HTML)