sql – 在oracle中插入包含引号的字符串

如何在oracle中插入包含引号的字符串?
我的代码
INSERT INTO TIZ_VADF_TL_MODELS (name)
VALUES ('xxx'test'yy');

如果我使用

INSERT INTO TIZ_VADF_TL_MODELS (name)
VALUES ("xxx'test'yy");

我得到标识符太长错误,因为xxx’test’yy是clob.

我怎样才能做到这一点?

谢谢.

解决方法

你也可以使用 ‘alternative quoting mechanism’ syntax
INSERT INTO TIZ_VADF_TL_MODELS (name)
VALUES (q'[xxx'test'yy]');

紧接在第一组引号内的字符对,在这种情况下为[],用于界定引用的文本;其中的单引号不必转义.当然,你不能在字符串本身内,但你可以选择自己的分隔符,这样就可以避免它出现问题; ]它本身仍然可以.

这可能比确保单引号被转义更简单,这可能会有点混乱,或者至少难以阅读和调试.

SQL Fiddle.

相关文章

SELECT a.*,b.dp_name,c.pa_name,fm_name=(CASE WHEN a.fm_n...
if not exists(select name from syscolumns where name=&am...
select a.*,pano=a.pa_no,b.pa_name,f.dp_name,e.fw_state_n...
要在 SQL Server 2019 中设置定时自动重启,可以使用 Window...
您收到的错误消息表明数据库 'EastRiver' 的...
首先我需要查询出需要使用SQL Server Profiler跟踪的数据库标...