TableA columnA columnB
A 1&2 sss
select * from A where columnA like '%1&2%';--------------------提示输入变量。
如果想要根据clomnA值,查询sss,怎么办?
分析:由于&是oracle中的变量字符(特殊字符)。因此需要将&设置为非特殊字符才能正常查询。
解决:set define off
select * from A where columnA like ’1&2‘;
set define off解释:
set define off关闭替代变量功能 在SQL*Plus中默认的"&"表示替代变量,也就是说,只要在命令中出现该符号,SQL*Plus就会要你输入替代值。这就意味着你无法将一个含有该符号的字符串输入数据库或赋给变量,如字符串“SQL&Plus”系统会理解为以“SQL”打头的字符串,它会提示你输入替代变量 Plus的值,如果你输入ABC,则最终字符串转化为“SQLABC”。 set define off 则关闭该功能,“&”将作为普通字符,如上例,最终字符就为“SQL&Plus” set define off关闭替代变量功能 set define on 开启替代变量功能 set define * 将默认替代变量标志符该为“*”(也可以设为其它字符)
本文详细介绍了如何解决SQL查询中遇到的特殊字符问题,并通过使用setdefineoff关闭替代变量功能来确保字符串正确解析,从而实现根据特定条件查询数据库。文章深入分析了SQL查询中的字符处理规则,提供了实用的解决方法。

被折叠的 条评论
为什么被折叠?



