我的编程空间,编程开发者的网络收藏夹
学习永远不晚

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

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

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

这篇文章给大家介绍如何进行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特殊字符的处理就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

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

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

怎么对@PathVariable中的特殊字符进行处理

这期内容当中小编将会给大家带来有关怎么对@PathVariable中的特殊字符进行处理,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。 @GetMapping(value="/user/{useraccou
2023-06-06

json特殊字符串如何处理

在处理 JSON 中的特殊字符串时,可以使用以下方法:1. 转义特殊字符:对于包含特殊字符的字符串,可以使用反斜杠(\)来转义它们。例如,双引号可以用 \" 来表示,反斜杠可以用 \\ 来表示。2. 使用 Unicode 转义序列:对于无法
2023-09-12

Python处理mysql特殊字符的问题

有的时候我们会去扫表,然后拿出扫的结果再到另一张表里去查信息。比如下面一段index_sql_str = "select %s from user where %s = %d" % ("social_id", "user_id", u_id
2022-05-17

mysql如何去掉字符串中的特殊字符

如何从 mysql 字符串中移除特殊字符?使用 regexp_replace() 函数匹配所有非字母数字字符和空格。使用 translate() 函数将特殊字符翻译为空字符串。使用 trim() 函数移除字符串两端的特殊字符。使用字符串方法
mysql如何去掉字符串中的特殊字符
2024-06-14

批处理bat如何判断是否特殊字符

这篇文章给大家分享的是有关批处理bat如何判断是否特殊字符的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。批处理判断是否为特殊字符用于判断输入的一个字符是否为"&^>中的符号。注意,匹配字符串中的空格不可省略!批处
2023-06-08

python3如何去除字符串中的特殊字符

这篇文章主要介绍了python3如何去除字符串中的特殊字符,在平时处理字符串的时候,经常会遇到字符串中夹杂着我们不希望看到的特殊字符,那么如何处理这些特殊字符呢,今天就跟着小编来看看吧
2023-05-17

Oracle怎么处理VARCHAR列中的特殊字符

在Oracle中处理VARCHAR列中的特殊字符,可以使用函数或者字符串替换的方法来处理。下面是一些常用的方法:使用REPLACE函数来替换特殊字符:可以使用REPLACE函数来将特殊字符替换为指定的字符。例如,可以使用以下语句将字符串中的
Oracle怎么处理VARCHAR列中的特殊字符
2024-04-09

批处理中处理特殊字符的几种方法小结

处理批处理中特殊字符的方法包括转义字符、字符代码、特殊变量、FOR命令和REM命令。转义字符指示解释器将特殊字符视为普通字符。字符代码是表示特殊字符的数字值。特殊变量包含特殊字符的代码值。FOR命令可用于迭代字符。REM命令可用于注释包含特殊字符的行。
批处理中处理特殊字符的几种方法小结
2024-04-02

java特殊字符转义处理的方法是什么

在Java中,可以使用反斜杠(\)来转义特殊字符。以下是一些常见的特殊字符转义序列:- \n:换行- \t:制表符- \r:回车- \b:退格- \f:换页- \’:单引号- \”:双引号- \\:反斜杠例如,要在字符串中插入一个换行符,可
2023-08-11

Spring Boot如何实现敏感词及特殊字符过滤处理

这篇文章主要介绍“Spring Boot如何实现敏感词及特殊字符过滤处理”,在日常操作中,相信很多人在Spring Boot如何实现敏感词及特殊字符过滤处理问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Spr
2023-06-20

java特殊字符转义处理的方法有哪些

使用双反斜杠"\“: 在特殊字符前添加一个反斜杠来转义。例如,要表示一个双引号字符”,可以写成"。使用Unicode编码:可以使用Unicode编码表示特殊字符。例如,要表示一个双引号字符",可以写成"\u0022"。使用字符串转义工具类:
java特殊字符转义处理的方法有哪些
2024-03-01

Linux中如何使用shell下的特殊字符

这篇文章给大家分享的是有关Linux中如何使用shell下的特殊字符的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。一、快速在目录之间切换。在Linux操作系统的文本模式下,在目录之间进行切换都需要通过命令来完成。
2023-06-17

linux终端对特殊字符的处理方法是什么

在Linux终端中,特殊字符通常由转义字符来进行处理。转义字符是以反斜杠(\)开头的字符,用于表示特殊含义的字符。以下是常见的特殊字符与对应的转义序列:1. 换行符:\n2. 回车符:\r3. 制表符:\t4. 倒退符:\b5. 反斜杠:\
2023-09-16

编程热搜

目录