时间:2021-05-24
Postgresql数据库运行下面insert命令
insert into mapping_mac_brand(_id,mac,brand) values(777,'D86595','Toy\'s Myth Inc.')提示下面的警告:
Warning: nonstandard use of \' in a string literal
HINT: Use '' to write quotes in strings or use the escape string syntax(E...')
string literal :字符串字面量
escape string:转义字符串
escape character:转义字符
Escape Sequence:转义字符串
转义字符:
所有的ASCII码都可以用“\”加数字(一般是8进制数字)来表示。而C中定义了一些字母前加"\"来表示常见的那些不能显示的ASCII字符,如\0,\t,\n等,就称为转义字符,因为后面的字符,都不是它本来的ASCII字符意思了。
在Java中,不管是String.split(),还是正则表达式,有一些特殊字符需要转义, 这些字符是 ( [ { / ^ - $ ¦ } ])。
Java中转义方法为字符前面加上"\\",这样在split、replaceAll时就不会报错了; 不过要注意,String.contains()方法不需要转义。
但是对于下面表格指定的字符,还是一个\即可转义。比如\n。
字母前面加上反斜线"\"来表示那些不能显示的ASCII字符.称为转义字符.如\0,\t,\n等,就称为转义字符,因为后面的字符,都不是它本来的ASCII字符意思了。
所有的转义字符和所对应的意义:
转义字符
意义
ASCII码值(十进制)
\a
响铃(BEL)
007
\b
退格(BS) ,将当前位置移到前一列
008
\f
换页(FF),将当前位置移到下页开头
012
\n
换行(LF) ,将当前位置移到下一行开头
010
\r
回车(CR) ,将当前位置移到本行开头
013
\t
水平制表(HT) (跳到下一个TAB位置)
009
\v
垂直制表(VT)
011
\\
代表一个反斜线字符''\'
092
\'
代表一个单引号(撇号)字符
039
\"
代表一个双引号字符
034
\0
空字符(NULL)
000
\ddd
1到3位八进制数所代表的任意字符
三位八进制
\xhh
1到2位十六进制所代表的任意字符
二位十六进制
3.解决方法
1.修改数据库配置,让数据库支持\作为转义字符
早期Postgresql普通字符串中的\是作为转义字符对待的,所以\\最终会认为是\。但是这是不符合SQL标准的,所以在PG 9.1及以后,普通字符串中的\不会被任务是转义字符,而E'xx\x'中的\才会被当作是转义字符。
为了使以前的代码可以在新的PG版本中运行,便有了standard_conforming_strings这个选项,这个选项默认是on,表示按照SQL标准处理字符串,当设置为off时,按照PG的旧版本处理字符串。运行下面命令,开启这个选项即可:
ALTER ROLE xx IN DATABASE yy SET standard_conforming_strings TO off;2. 用新版本支持的转义字符。''或者 E'',将含有转义的字符串放在单引号里面
'\\' 或者 E'\\'补充:PG特殊字符的转义
实例1
imos=# select * from test; name ------ c_d ab _b_c(3 rows)imos=# select * from test where name like '_b%'; name ------ ab _b_c(2 rows)imos=# select * from test where name like 'd_b%' escape 'd'; name ------ _b_c(1 row)imos=# select * from test where name like '\_b%' ; name ------ _b_c(1 row)以上为个人经验,希望能给大家一个参考,也希望大家多多支持。如有错误或未考虑完全的地方,望不吝赐教。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
nl2br();//\ntoaddslashes();stripslashes();//对数据库操作时,转义特殊字符chop();//除去字符串右边空格trim
为了避免操作数据库的风险因此计划每天对postgresql数据库进行定时备份1.服务器地址:备份服务器地址10.10.10.101(虚构)postgresql数
Python操作PostgreSql数据库(基本的增删改查)操作数据库最快的方式当然是直接用使用SQL语言直接对数据库进行操作,但是偶尔我们也会碰到在代码中操作
PostgreSQL是一款功能强大的开源关系型数据库,本文使用python实现了对开源数据库PostgreSQL的常用操作,其开发过程简介如下:一、环境信息:1
前言最近将使用爬虫爬取的链接保存到mysql数据库中时,发现我将链接使用json_encode保存时候,在数据库中却显示了转义字符,我并不需要这转义的,看起来不