sql的转义字符单引号

在SQL中,我们都知道单引号 ' 表示字符串的开始和结束符号,如:

select * from students where name = '小明';

但如果字符串里面有单引号时,应该怎么查询呢?

这是我最近遇到的一个问题,需求是对一张表的数据进行更新,但各个环境的数据并不一致,只能通过拼接的方式生成适合对应环境的变更脚本。更新语句格式如下:

1 update students set grade = '一年级' where grade_id = '01' and grade is null;
2 update students set grade = '二年级' where grade_id = '02' and grade is null;
3 ...
4 --只是举例,实际就是各个环境字段值不一致,需要先根据环境拼接变更脚本

拼接sql语句的脚本初始如下:

--db2数据库使用下面的语句
select 'update students set grade = ' || grade || ' where grade_id = ' || grade_id || ' and grade is null;' from classes
where grade_id in (select grade_id from students where grade_id is not null and grade is null);

--mysql数据库使用下面的语句
select concat('update students set grade = ',grade,' where grade_id = ',grade_id,' and grade is null;') from classes 
where grade_id in (select grade_id from students where grade_id is not null and grade is null);

 结果如下:

可以发现,字符串值没有单引号,直接运行会报错。google后找到解决办法。sql单引号

sql的转义字符单引号 ' ,可以对字符串中的单引号进行转义,使其表示字符串值 ' ,这样如果要查询 name 为 小'明 的值,其sql语句如下:

select * from students where name = '''';

所以上面的拼接脚本修改如下,即可生成正确的update语句。

1 --db2数据库使用下面的语句
2 select 'update students set grade = ''' || grade || ''' where grade_id = ''' || grade_id || ''' and grade is null;' from classes
3 where grade_id in (select grade_id from students where grade_id is not null and grade is null);
4 
5 --mysql数据库使用下面的语句
6 select concat('update students set grade = ''',grade,''' where grade_id = ''',grade_id,''' and grade is null;') from classes 
7 where grade_id in (select grade_id from students where grade_id is not null and grade is null);
8 
9 --注意三个逗号需连续,且与其他字符间的空格

 

转载于:https://www.cnblogs.com/readerman/p/10213375.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值