在线精品99_中国九九盗摄偷拍偷看_91免费版在线观看_91.app_91高清视频在线_99热最新网站

如何进行MYSQL特殊字符的处理

159次阅读
没有评论

共计 4114 个字符,预计需要花费 11 分钟才能阅读完成。

这篇文章给大家介绍如何进行 MYSQL 特殊字符的处理,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。

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

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

工作内容简介:有一批用户 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 -h227.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 -h227.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 一下以免大家在这里浪费时间。

关于如何进行 MYSQL 特殊字符的处理就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-07-19发表,共计4114字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)
主站蜘蛛池模板: 毛片免费永久不卡视频观看 | 亚洲天堂成人 | 亚洲综合色丁香婷婷六月图片 | 天天撸夜夜操 | 日韩在线免费视频 | 亚洲成a人片在线观看www | 久草一区| 午夜dj高清免费观看视频 | 国产999在线观看 | 一色屋精品免费视频 视频 一色屋精品视频在线观看 一色屋色费精品视频在线观看 | 午放福利视频在线播放 | 精品久久成人免费第三区 | 亚洲毛片在线播放 | 国产人妻人伦精品1国产 | 免费男人添女人下身视频高清 | 精品国产乱码久久久久久口爆网站 | 在线精品日韩一区二区三区 | 四虎精品影院4hutv四虎 | 广东少妇大战黑人34厘米视频 | 狠狠操中文字幕 | 国产高清一区 | 伊人久久大香线蕉影院95 | 狼友av永久网站免费观看孕交 | 久久久久亚洲av成人片一区 | 亚洲精品国产精品国自产 | 成人午夜精品 | 又刺激又黄的一级毛片 | 日本强伦片中文字幕免费看 | 亚洲中文字幕无码中文字在线 | 日本国内一区二区三区 | 国产剧情麻豆女教师在线观看 | 欧美综合专区 | 色综合久久中文字幕无码 | 女人18毛片a级毛片免费视频 | 思思久久96热在精品国产 | 中文字幕人妻无码专区 | 日本sm/羞辱/调教/捆绑视频 | 日日摸夜夜夜夜夜添 | 国产日韩欧美一区二区东京热 | 小说区图片区 | 国产免费小视频在线观看 |