您好,欢迎访问一九零五行业门户网

在Oracle SQL语句中,单引号和双引号的使用

/**在oracle中 双引号 被当做一个普通的字符串来处理**/select
/**在oracle中 双引号 被当做一个普通的字符串来处理**/
/**测试一下三个单引号的情况  : ora-01756:引号内的字符串没有正确结束**/
select ''' from dual;
/**测试一下四个单引号的情况 : 结果为一个 ' (单引号)  **/
--说明 第二个单引号被oracle默认为是 转义字符
select '''' from dual;
/**验证一下第二个单引号是转义字符的推断,在第二个和第三个单引号之间增加一个空格**/
--提示错误:ora-0092:未找到要求的from关键字 说明刚才的推论是对的
select '' '' from dual;
/**在动态sql里面会经常用到单引号的,例如需要动态增加like,写一个测试的小例子**/
declare
    v_sql varchar2(200);
    n_count number(4);
    v_name varchar2(100);
begin
    v_name := '名字';
    v_sql := 'select count(1) from t1 where 1=1';
    v_sql := concat(v_sql,' and t1.name like ''%'||v_name||'%''');
     execute immediate v_sql into n_count;
     dbms_output.put_line('n_count'||'==>'||n_count);
end;
/**总结:
1、在oracle中,双引号是被当做一个普通的字符串来处理的。
2、在一对单引号包含的语句中,必须有一对相邻的单引号表示一个单引号
3、两个相邻的单引号的作用,第一个是用来表示转义字符,后面一个表示真正的单引号
**/

其它类似信息

推荐信息