oracle&字符的转义

本文详细介绍了在Oracle数据库中处理特殊字符编码时遇到的问题,包括如何在SQL语句中正确使用&符号,提供了三种解决方案:设置defineoff、ASCII编码转义和直接字符串形式输入,帮助开发者避免编码错误。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

//增加一菜单时
insert into hsi_menu (C_SYSNAME, L_MENUTYPE, C_PARENTCODE, C_MENUCODE, C_MENUNAME, C_DESCRIBE, L_SHORTCUT, L_FUNCTIONTYPE, C_DLLFILE, C_DLLFUNCTION, L_FUNCTIONID, C_COMMAND, C_ICONFILENAME, L_OUTLOOK, L_ORD, C_RIGHTCODE, C_RIGHTCODE2, C_LEAF, C_ISUSE, C_VERSIONTYPE, C_AUTHCODE)
values ('FUNDCRM', 1, '  092304', '  09230406', '额度分配监控', null, null, 2, 'sale', 'SaleProjectActionTransfer.jsp?svcrightflag=MONITOR&latitude=quota', 0, null, null, 1, 4, null, null, '1', '1', 'trust', null);
commit;


--.oracle中&符是用来定义临时变量的,所以要在oracle中使用&符需要对这个符号进行转义(ASCII编码)


解决方法
1.在执行语句前加set define off;(意思是去掉oracle自定义的字符含义,还原它本来的意思)
set define off;
delete from hsi_menu h where h.c_sysname = 'FUNDCRM' and h.c_menucode = '  09230406';
insert into hsi_menu (C_SYSNAME, L_MENUTYPE, C_PARENTCODE, C_MENUCODE, C_MENUNAME, C_DESCRIBE, L_SHORTCUT, L_FUNCTIONTYPE, C_DLLFILE, C_DLLFUNCTION, L_FUNCTIONID, C_COMMAND, C_ICONFILENAME, L_OUTLOOK, L_ORD, C_RIGHTCODE, C_RIGHTCODE2, C_LEAF, C_ISUSE, C_VERSIONTYPE, C_AUTHCODE)
values ('FUNDCRM', 1, '  092304', '  09230406', '额度分配监控', null, null, 2, 'sale', 'SaleProjectActionTransfer.jsp?svcrightflag=MONITOR&latitude=quota', 0, null, null, 1, 4, null, null, '1', '1', 'trust', null);
commit;


2.用(ASCII编码)对&进行转义chr(38)
insert into hsi_menu (C_SYSNAME, L_MENUTYPE, C_PARENTCODE, C_MENUCODE, C_MENUNAME, C_DESCRIBE, L_SHORTCUT, L_FUNCTIONTYPE, C_DLLFILE, C_DLLFUNCTION, L_FUNCTIONID, C_COMMAND, C_ICONFILENAME, L_OUTLOOK, L_ORD, C_RIGHTCODE, C_RIGHTCODE2, C_LEAF, C_ISUSE, C_VERSIONTYPE, C_AUTHCODE)
values ('FUNDCRM', 1, '  092304', '  09230406', '额度分配监控', null, null, 2, 'sale', 'SaleProjectActionTransfer.jsp?svcrightflag=MONITOR'||chr(38)||'latitude=quota', 0, null, null, 1, 4, null, null, '1', '1', 'trust', null);
commit;


3.不转义,直接字符串的形式写进去。
insert into hsi_menu (C_SYSNAME, L_MENUTYPE, C_PARENTCODE, C_MENUCODE, C_MENUNAME, C_DESCRIBE, L_SHORTCUT, L_FUNCTIONTYPE, C_DLLFILE, C_DLLFUNCTION, L_FUNCTIONID, C_COMMAND, C_ICONFILENAME, L_OUTLOOK, L_ORD, C_RIGHTCODE, C_RIGHTCODE2, C_LEAF, C_ISUSE, C_VERSIONTYPE, C_AUTHCODE)
values ('FUNDCRM', 1, '  092304', '  09230406', '额度分配监控', null, null, 2, 'sale', 'SaleProjectActionTransfer.jsp?svcrightflag=MONITOR'||'&'||'latitude=quota', 0, null, null, 1, 4, null, null, '1', '1', 'trust', null);
commit;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值