--匹配符 % 匹配零或者多个字符,例如A% 号只要时以A开头的全都能匹配到。
select * from student2 where sname like 'A%';
--同理根据昨天学到的转换大小写的方式,我们同样可以在使用匹配符号查询时,使用upper(),lower(),来转换大小写进行匹配。
select * from student2 where upper(sname) like 'A%';
select * from student2 where lower(sname) like 'a%';
--下划线 _ 匹配符,匹配单一任何字符(下划线)
select * from student2 where sname like 'A_';
--当然同理,字段大小写转换同样生效。
select * from student2 where upper(sname) like 'A_';
select * from student2 where lower(sname) like 'a_';
--如何将sno为1的同学名字更新成我的老婆“一行琉璃”的名字?(使用update 表明 set 字段=’’ where sno = ;即可)
update student2 set sname='一行琉璃' where sno=1;
已更新 1 行。
SQL> select * from student2;
SNO SNAME BIRTHDAY
---------- ---------- --------------
1 一行琉璃 11-1月 -01
2 B 21-1月 -80
3 AA 23-2月 -81
4 23-2月 -82
--将sno为2的学生姓名改成’一行琉璃璃酱’,此时我发现报错
SQL> update student2 set sname='一行琉璃璃酱' where sno=2;
update student2 set sname='一行琉璃璃酱' where sno=2
*
第 1 行出现错误:
ORA-12899: 列 "SCOTT"."STUDENT2"."SNAME" 的值太大 (实际值: 12, 最大值: 10)
--原来是字段定义长度不够,缩短为‘琉璃璃酱’即可成功,所以先试一下。
SQL> update student2 set sname='琉璃璃酱' where sno=2;
已更新 1 行。
SQL> select * from student2;
SNO SNAME BIRTHDAY
---------- ---------- --------------
1 一行琉璃 11-1月 -01
2 琉璃璃酱 21-1月 -80
3 AA 23-2月 -81
4 23-2月 -82
--ok,没有问题,突然想到之前学过,改字段长度,那就改一下,再把名变回来。
SQL> alter table student2 modify SNAME varchar2(20);
表已更改。
SQL> update student2 set sname='一行琉璃璃酱' where sno=2;
已更新 1 行。
SQL> select * from student2;
SNO SNAME BIRTHDAY
---------- -------------------- --------------
1 一行琉璃 11-1月 -01
2 一行琉璃璃酱 21-1月 -80
3 AA 23-2月 -81
4 23-2月 -82
--ok了家人们,也是直接使用alter table 表名 modify 要更改的字短名 字段的数据类型(变更的长度); 然后就可以更改名字了。
--关于模糊匹配符的详细介绍,这位博主,已经说的很详细了。
oracle中带有特殊符号的模糊查询_oracle \符号用法-CSDN博客
oracle中带有特殊符号的模糊查询
首先讲一下Oracle模糊查询
Oracle模糊查询可使用的通配符,Oralce中SQL语句提供了四种匹配模式:
% 零或者多个字符
_ 单一任何字符(下划线)
\ 特殊字符
[] 在某一范围内的字符,如[0-9]或者[aeth]
[^] 不在某范围内的字符,如[^0-9]或者[^aeth]
后两种, 需要Oracle 10g以上使用支持like的正则regexp_like
[ ]:表示括号内所列字符中的一个(类似正则表达式)。
指定一个字符、字符串或范围,要求所匹配对象为它们中的任一个
如 [ ] 内有一系列字符(01234、abcde之类的)则可略写为“0-4”、“a-e”
[^ ] :表示不在括号所列之内的单个字符。其取值和 [] 相同,但它要求所匹配对象为指定字符以外的任一个字符。
注:oracle like 不支持正则,你可以使用支持like的正则regexp_like
select * from table_name where regexp_like(name,'[张李王]三');
由于通配符的缘故,导致我们如果想要查询包括这些特殊字符的内容“%”、“_”、“[”的语句无法正常实现
oracle中的模糊查询,带有特殊符号
用like语句查询的话可以,但是有特殊符号的话不能识别,如:#,%,_ 等
第一种方法:
可以用 regexp_like(字段名 ,'带有特殊符号的模糊字') 这个查询
例如:
select * from user_souce t
where to_char(t.us_time, 'yyyymmdd') = '20120615' and regexp_like(t.us_from, 'hello[Mr.hailey]');
第二种方法:转义特殊字符,转义符可以自己定义,用escape '转义符'定义即可
例如:
-- 查找所有包含'_'的
select * from emp where ename like '%?_%' escape '?'; --转义符为问号?
select * from emp where ename like '%/_' escape '/'; --转义符为斜杠/
--查找所有以_结尾的
select * from emp where ename like '%\_' escape '\'; --转义符为反斜杠\
同理,通过这种方法查找含有'%'的所有字段:
select * from emp where ename like '%\%%' escape '\';
但是'&'不能通过转义字符查找
如果按上面的写法,
select * from emp where ename like '%\&' escape '\';
会提示:ORA-01424: 转义符之后字符缺失或非法
可以通过另外的方式进行转义:
select ascii('&') from dual;
ASCII('&')
----------
38
select * from emp where ename like '%' || chr(38) || '%';
在oracle中chr()函数和ascii()是一对反函数
chr()函数将ASCII码转换为字符:ASCII码 --> 字符
ascii('字符')函数获得该字符的ascii码值,将字符转换为ASCII码:字符 --> ASCII码
但是,注意%不能用这种方法转义(%号的ascii码为37)因为转出来还是一个%号,还是会当做通配符找出所有的数据
--单引号的转义
如果按上面的写法,
select * from emp where ename like '%\'%' escape '\';
会提示:ORA-01756:引号内的字符串没有正确结束,因为不能正确识别结束
--查找所有含有单引号的名字
select * from emp where ename like '%''%';
--怎么查找以我老婆’一行琉璃璃’开头的学生姓名呢?(联系上文,我们直接使用_)。
SQL> select * from student2 where sname like '一行琉璃璃_';
SNO SNAME BIRTHDAY
---------- -------------------- --------------
2 一行琉璃璃酱 21-1月 -80
--好,现在我们查一下姓名长度为4的学生信息。首先为了方便要插入一个新的记录。(4,AAAA,20010216),这条记录要怎么插入呢?
--直接使用insert into 表名(字段,字段,字段) values(要插入的记录),注意字符要’’,日期要to_date()转换一下。
SQL>insert into student2(sno,sname,birthday) values(4,'AAAA',to_date('20010216','yyyymmdd'));
//这里不知道什么愿意,很大空格,我直接复制到文档看的,但是无伤大雅,不影响复制//
已创建 1 行。
SQL> select * from student2;
SNO SNAME BIRTHDAY
---------- -------------------- --------------
4 AAAA 16-2月 -01
1 一行琉璃 11-1月 -01
2 一行琉璃璃酱 21-1月 -80
3 AA 23-2月 -81
4 23-2月 -82
SQL> delete from student2 where sname like 'AAAA';
已删除 1 行。
SQL> select * from student2;
SNO SNAME BIRTHDAY
---------- -------------------- --------------
1 一行琉璃 11-1月 -01
2 一行琉璃璃酱 21-1月 -80
3 AA 23-2月 -81
4 23-2月 -82
SQL> insert into student2(sno,sname,birthday) values(5,'AAAA',to_date('20010216','yyyymmdd'));
已创建 1 行。
SQL> select * from student2;
SNO SNAME BIRTHDAY
---------- -------------------- --------------
5 AAAA 16-2月 -01
1 一行琉璃 11-1月 -01
2 一行琉璃璃酱 21-1月 -80
3 AA 23-2月 -81
4 23-2月 -82
--以上,我插入数据sno号重复了,所以只能删掉重建,格式;delete from 表名 where 约束条件;好了,我刚刚插入了第五行。
--现在我们发现sno学号5的记录sname的字段长度(4)筛选,能查出两条信息。
SQL> select * from student2 order by sno;
SNO SNAME BIRTHDAY
---------- -------------------- --------------
1 一行琉璃 11-1月 -01
2 一行琉璃璃酱 21-1月 -80
3 AA 23-2月 -81
4 23-2月 -82
5 AAAA 16-2月 -01
SQL> select * from student2 where length(sname)=4;
SNO SNAME BIRTHDAY
---------- -------------------- --------------
5 AAAA 16-2月 -01
1 一行琉璃 11-1月 -01
--ok,我们可以知道,varchar2(10 char)表示为可以最大容纳10个字的字符串,而不用考虑这个字占用多少个字节,该例则可最大容纳10个汉字,或者10个英文字符,但最大不得超过4000个字节。
1、char
(1)char的长度是固定的。比如说,你定义了char(20),即使你你插入abc,不足二十个字节,数据库也会在abc后面自动加上17个空格,以补足二十个字节;
(2)char是区分中英文的。中文在char中占两个字节,而英文占一个,所以char(20)你只能存20个字母或10个汉字。
char适用于长度比较固定的,一般不含中文的情况。
2、varchar/varchar2
(1)varchar是长度不固定的。比如说,你定义了varchar(20),当你插入abc,则在数据库中只占3个字节。
(2)varchar同样区分中英文。这点同char。
(3)varchar2基本上等同于varchar。它是oracle自己定义的一个非工业标准varchar,不同在于,varchar2用null代替varchar的空字符串。
varchar/varchar2适用于长度不固定的,一般不含中文的情况。
3、nvarchar/nvarchar2
(1)nvarchar和nvarchar2是长度不固定的;
(2) nvarchar不区分中英文。比如说:你定义了nvarchar(20),你可以存入20个英文字母/汉字或中英文组合,这个20定义的是字符数而不是字节数;
(3)nvarchar2基本上等同于nvarchar,不同在于nvarchar2中存的英文字母也占两个字节。
大多数情况下,ORACLE中的国家字符集是默认的,以下结论成立:
如果要省存储空间,建表时,字段内容里如果中文占了大多数,就用nvarchar2类型;如果内容是英文和数字为主的字符串,就用varchar2类型。
注意:
1、ORACLE中的国家字符集,只有在数据类型为NCHAR/NVARCHAR/NCLOB时才会被使用,也就是前面带N(national)的字符类型;
2、ORACLE默认国家字符集为AL16UTF16,完全对应UNICODE的UTF-16标准(有别于数据库字符集)
3、ORACLE中的UTF-8,不是标准的UTF-8,而是CESU-8。
varchar/varchar2 与 nvarchar/nvarchar2
这四个类型都属于变长字符类型。
(1)varchar和varchar2的区别在与后者把所有字符都占两字节,前者只对汉字和全角等字符占两字节。
(2)nvarchar和nvarchar2的区别和上面一样。与上面不同的是,是根据Unicode标准所进行的定义的类型,通常用于支持多国语言类似系统的定义。
长度赋值
1、char [ ( n ) ]
固定长度,非 Unicode 字符数据,长度为 n 个字节。n 的取值范围为 1 至 8,000,存储大小是 n 个字节。
2、varchar [ ( n | max ) ]
可变长度,非 Unicode 字符数据。n 的取值范围为 1 至 8,000。max 指示最大存储大小是 2^31-1 个字节。存储大小是输入数据的实际长度加 2 个字节,用于反映存储的数据的长度。所输入数据的长度可以为 0 个字符。
* 如果列数据项的大小一致,则使用 char。
* 如果列数据项的大小差异相当大,则使用 varchar。
* 如果列数据项大小相差很大,而且大小可能超过 8,000 字节,请使用 varchar(max)。
如果未在数据定义或变量声明语句中char 或 varchar 数据类型指定 n,则默认长度为 1。
如果在使用 CAST 和 CONVERT 函数时char 或 varchar 数据类型未指定 n,则默认长度为 30。
当执行 CREATE TABLE 或 ALTER TABLE 时,如果 SET ANSI_PADDING 为 OFF,则定义为 NULL 的 char 列将作为 varchar 处理。
3、nvarchar [ ( n | max ) ]
可变长度 Unicode 字符数据。n 值在 1 到 4,000 之间(含)。max 指示最大存储大小为 2^31-1 字节。存储大小是所输入字符个数的两倍 + 2 个字节。所输入数据的长度可以为 0 个字符。
Oracle推荐使用varchar2、nvarchar2。实际varchar、nvarchar可能都找不到了。
1、和VARCHAR不同的是,VARCHAR2把空串等同于null处理,这也是为什么ORACLE推荐使用VARCHAR2类型的原因。当国家字符集为utf8时,允许的最大列大小为4000个字符;当国家字符集为al16utf16时,允许的最大列大小为2000个字符。
2、nvarchar2列的最大字节长度为4000。必须同时满足字节限制和字符限制,因此nvarchar2列中实际允许的最大字符数是可以用4000字节写入的字符数。
varchar2(N) 与 varchar2(N char) 的区别(最大存储大小都是 2^31-1 个字节)
1、varchar2(N):可以存储N byte长度,与字符数无关;例如varchar2(3),可以存储3个byte长度,如'啊a'、'aaa',与字符数无关;
2、varchar2(N char):可以存储N个字符(包括字母和汉字),与字节(byte)长度无关;例如varchar2(3 char),可以存储3个字符(包括字母和汉字),如'啊啊啊'、'aaa'、'啊aa',与字节(byte)长度无关;
关于上面var与var2的关系引用原文链接:Oracle字段类型char、varchar2、nvarchar2的区别与使用_oracle varchar2-CSDN博客