十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
一般在end;(注意有分号)后加反斜杠,代表是要执行某个存储过程,如果没有反斜杠,则代表是普通换行。这种情况一般用于oracle中的命令窗口。
成都创新互联服务项目包括东坡网站建设、东坡网站制作、东坡网页制作以及东坡网络营销策划等。多年来,我们专注于互联网行业,利用自身积累的技术优势、行业经验、深度合作伙伴关系等,向广大中小型企业、政府机构等提供互联网行业的解决方案,东坡网站推广取得了明显的社会效益与经济效益。目前,我们服务的客户以成都为中心已经辐射到东坡省份的部分城市,未来相信会继续扩大服务区域并继续获得客户的支持与信任!
如图:
此时,如果按回车键,是无法执行存储过程的。如果按回车,则是换行。
如果改成如下,则代表执行成功。
一、符号的处理方案
1、在前面加上语句set define off
首先要理解是做什么的,这个符合在Oracle中表示替代变量,执行时会提示用户输入,然后以及后面的字符会替换为用户输入的字符。
set define off的作用是关闭替代变量功能。当然你还可以把替代变量改为其它符号,比如改为*号,输入这个命令:set define *
2、在SQL语句中将分拆并替换成chr(38)
38是的ASCII码,实例sql
3、分拆出号,这也是最简单直接的方法
二、符号'的处理方案
1、直接转义
2、分拆转义
3、分拆并替换成chr(39)
在字段里查找'%',涉及到Oracle的转义字符,现总结如下:
SQL select * from test;
TEST
--------------------
sdd_kk
d'd
dfsfsa
dffa%asfs
12345
1%2345
1%54321
2%54321
%%54321
AB
已选择9行。
其中包含特殊的字符分别为%,_,,有可能包含这些字符的数据含有错误,或者需要查找包含这些字符的数据。
SQL select * from test where test like 'sdd _%' escape ' ';
TEST
--------------------
sdd_kk
转义字符为' ';
SQL select * from test where test like 'sdd\_%' escape '\';
TEST
--------------------
sdd_kk
转义字符为'\';
SQL select * from test where test like 'sdd=_%' escape '=';
TEST
--------------------
sdd_kk
转义字符为'=';
SQL select * from test where test like 'sdd/_%' escape '/';
TEST
--------------------
sdd_kk
转义字符为'/';
SQL select * from test where test like 'sddd_%' escape 'd';
未选定行
转义字符为d,没有实现转义功能;
SQL select * from test where test like '%\_%' escape '\';
TEST
--------------------
sdd_kk
查找包含所有'_'的字段。
同理:通过这种方法查找含有'%'的所有字段:
SQL select * from test where test like '%\%%' escape '\';
TEST
--------------------
dffa%asfs
1%2345
1%54321
2%54321
%%54321
但是''不能通过转义字符查找:
SQL select * from test where test like '%\%' escape'\';
select * from test where test like '%\%' escape'\'
*
第 1 行出现错误:
ORA-01424: 转义符之后字符缺失或非法
可以通过另外的方式进行转义:
SQL select ascii('') from dual;
ASCII('')
----------
38
SQL select * from test where test like '%'||chr(38)||'%';
TEST
--------------------
AB
'''的转义:
SQL select * from test where test like '%''%';
TEST
--------------------
d'd
特殊符号的数据的插入
SQL insert into test values('testtest');
输入 test 的值: test
原值 1: insert into test values('testtest')
新值 1: insert into test values('testtest') -虽然插入,但是数据不对。
已创建 1 行。
SQL show define
define "" (hex 26)
SQL set define off
SQL show define
define OFF
SQL insert into test values('testtest');
已创建 1 行。
SQL show escape
escape OFF
SQL set escape on
SQL show escape
escape "\" (hex 5c)
SQL insert into test values('test\test');
已创建 1 行。
SQL select * from test;
TEST
--------------------
sdd_kk
d'd
dfsfsa
dffa%asfs
12345
1%2345
1%54321
2%54321
%%54321
AB
testtest
TEST
--------------------
testtest
testtest
已选择13行。
SQL commit;
提交完成。
SQL select * from test;
TEST
--------------------
sdd_kk
d'd
dfsfsa
dffa%asfs
12345
1%2345
1%54321
2%54321
%%54321
AB
testtest
TEST
--------------------
testtest
testtest
已选择13行。
SQL insert into test values('test\%test');
已创建 1 行。
SQL insert into test values('test\_test');
已创建 1 行。
SQL insert into test values('test\'test);
insert into test values('test'test)
*
第 1 行出现错误:
ORA-00917: 缺失逗号
SQL insert into test values('test''test');
已创建 1 行。
SQL select * from test;
TEST
--------------------
sdd_kk
d'd
dfsfsa
dffa%asfs
12345
1%2345
1%54321
2%54321
%%54321
AB
testtest
TEST
--------------------
testtest
testtest
test%test
test_test
test'test
已选择16行。
斜杠 就是让服务器执行前面所写的 SQL 脚本。
因为你普通的 select 语句, 一个分号,就可以执行了。
但是如果你的是存储过程, 那么遇到分号,就不能马上执行了。
这个时候,就需要通过 斜杠 来执行了。
下面是例子:
SQL set serveroutput on
SQL BEGIN
2 dbms_output.put_line('Hello World');
3 END;
4 /
Hello World
PL/SQL procedure successfully completed.