sql语句中有中文,符号等怎么处理

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了sql语句中有中文,符号等怎么处理相关的知识,希望对你有一定的参考价值。

我要执行一条update语句。类似这样:
update table set name='name' where name='你好(%><;'i9hh %()';
就这条语句,数据库中有这个name的记录,但是通过这个条件查找不到这条记录,也更新不了该记录。原因我试验了一下,就是符号造成的。

数据库中有很多记录,需要批量update,所以手工来修改不行了

请问应该怎么办?谢谢!我记得好像看过有个什么函数,就可以把这个字符串做个类似转义的操作,就好了。

谢谢
不能使用like,也查询不到记录,我通过实验,去掉字符串中的><和%可以,但是也要在字符串前后加%。具体原因不清楚,我想可能是mysql自己有什么规则。对了,忘记说了,我用的数据库是MYSQL5.1
这个name就是一种物品的名称,由于已经使用了系统,所以数据很多,而该物品名称使用的人员,输入的有中文,英文,符号,那么现在就是要根据这个名字来修改一些字段。
tj_angela 你说的我知道,但是解决不了我的问题,我不可能一条条的把脚本中的所有数据中的符号都加上\来转义
逐鹿传说 你说的我明白,但是如果去掉太多符号的话,查到数据就不准确哦了,符号就是数据,没有办法,而且我也不能一条条去掉符号,很多数据

没有什么例子啊,数据库脚本在公司,Excel的,里面是名称和时间,我根据名称(名称唯一),修改其他字段,其实现在只要能根据名称select到对应的那一条记录就可以。只是update的条件,现在用select * from table where name='你好(%><;'i9hh %()';都查不到这条记录,但是其实是有这条数据

对于特殊字符
要用到转义符
name like '%\%%' escape '\'意思就是保留\后面的一个字符,无视\
就是name中包含%的记录

你给几个改完的字段的例子阿
比如说'你好(%><;'i9hh %()'你要改成怎样
‘你不好%*#@)%’这个又要改成怎么
参考技术A 等号后面的字符里有“%”和“'”这两个字符需要使用转义字符sqlserver中的转义字符是单引号“'”
'你好(%><;'i9hh %()'
改成
'你好('%><;''i9hh '%()';
参考技术B 能不能用like 关键字呢?
update table set name='name' where name like '你好(%><;_i9hh %()';
---

奇怪噻

select * from table where name like '你好%' 查不到吗? 后面那些符号是想做什么呢 是记录里有那些符号吗

通过xml处理sql语句时对小于号与大于号的处理转换

当我们需要通过xml格式处理sql语句时,经常会用到<=>>=等符号,但是很容易引起xml格式的错误,这样会导致后台将xml字符串转换为xml文档时报错,从而导致程序错误。

这样的问题在iBatiS中或者自定义的xml处理sql的程序中经常需要我们来处理。其实很简单,我们只需作如下替换即可避免上述的错误:

原符号   <    <=    >    >=     &      ‘       "
替换符号 &lt; &lt;= &gt; &gt;= &amp; &apos; &quot;


错误的xml格式:

<?xml version="1.0" encoding="GBK"?> 

<queryForm token="32sdfj-349sfdnfs32-fsdf348imfg323-df34" tableName="HSY_T_CUSTOMER" pageSize="20" pageNo="1" orderColumn="" orderType="">  

<sqlCondition> AND START_DATE >= to_date(‘2013-01-01‘,‘yyyy-MM-dd‘) AND START_DATE <= to_date(‘2013-01-30‘,‘yyyy-MM-dd‘) </sqlCondition>  

</queryForm>  

 

在altova XMLSpy工具中会报错,xml不符合格式要求。



正确的xml格式:

<?xml version="1.0" encoding="GBK"?>  

<queryForm token="32sdfj-349sfdnfs32-fsdf348imfg323-df34" tableName="HSY_T_CUSTOMER" pageSize="20" pageNo="1" orderColumn="" orderType="">  

<sqlCondition> AND START_DATE &gt;= to_date(‘2013-01-01‘,‘yyyy-MM-dd‘) AND START_DATE &lt;= to_date(‘2013-01-30‘,‘yyyy-MM-dd‘) </sqlCondition>  

</queryForm>  

 

在altova XMLSpy工具中验证通过。

 

原文链接:http://blog.csdn.net/hu_shengyang/article/details/8513655

以上是关于sql语句中有中文,符号等怎么处理的主要内容,如果未能解决你的问题,请参考以下文章

sql 语句中 符号是啥意思?

通过xml处理sql语句时对小于号与大于号的处理转换

Mybatis的动态sql的处理

求助sql数据库字段特殊字符问题

sql语句中怎样将字符类型转换成数字类型

在 sql中 多行sql语句怎么执行,是从上往下 还是从下往上??????求解