Oracle学习笔记——基础一起学 3

--匹配符 % 匹配零或者多个字符,例如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博客

如果能帮到你请感谢我的老婆“一行琉璃”

  • 38
    点赞
  • 27
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值