一、查询语句
ORACLE 数据库中获得数据表中的结果,称为查询语句,其关键词是 select(下面其所有的示例均为scott模式下的对象)
1.1 查询语句基础
1.1.1 获得表中全部字段与结果
语法如下
select * from table_name;
示例
查询 雇员表的全部信息
1.1.2 获得表中需要的字段结果
说明
通过显示指定表中的字段名可以只显示需要字段
语法如下
select col1[,col2,col3....] from table_name;
示例
查询雇员表的雇员编号和雇员名
1.1.3 按照过条件过滤结果
说明
可以通过where关键字卡条件来过滤结果, 条件字段等于或者大于或者小于某个值等等,与可以多个条件连用
语法如下
select * from table_name where col1 ='XXXX';
示例1
查询雇员表的雇员编号为7934的结果
示例2
查询雇员表的部门编号为30,并且奖金大于300的结果
1.1.4 按照某个值排序查询的结果
默认的查询结果是随机显示的,但是可以通过关键词 order by 来使结果按照一定的规则排序显示,可以通过 ASC或者desc来指定升序还是降序排列,缺省为asc
语法
select * from table_name order by col1 [asc|desc];
示例
通过部门编号降序显示结果
1.2 高级查询语句
1.2.1 子查询
说明
子查询,主表的条件字段结果引用另一个表中的结果,其中子表的查询字段只能查询一个,可以引用子集的多行结果关键字为 in或者 not in,也可以只返回一行结果,关键字是=
语法
select * from table_name1 where col1 in | not in|= (select col1 from table_name2);
示例1
返回多个子结果
(注意子查询的条件,子查询的条件筛选是多个)
示例二
返回单个子结果
(注意子查询的条件,子查询的条件筛选是单个)
1.2.2多表等值关联查询
说明
1. 当查询结果需要引用其他表中结果,需要进行关联查询
2. 在from 后面接两个或两个以上的表
3. 确保关联表中的关联字段值是唯一的,否则会产生笛卡尔积
4. 如果在查询字段中有,两个表的字段都包含了该字段,则需要显示的指定字段来自于哪个表
5. 可以在表名后面跟别名
语法
select col1[,col2,col3....] from table_name1,table_name2 where tba1.col1=tab2.col1;
示例
将雇员表和部门表进行链接查询
(注意看,deptno字段,因为两个表都有该字段,所以需要显示的指定一个表,如果给表起了别名,则字段前指定表名也需要写表别名)
1.2.3 左关联查询
说明
1.哪个表名在前,哪个表就是左边,在后面的为右表
2. 左表的全部信息都会查询出来,右表的信息只有关联上的信息才会查询到,右表没有关联上的信息,则会显示为空,关键词 left join,也可以用(+)来关联
语法
select col1[,col2,col3....] from table_name1,table_name2 where tba1.col1=tab2.col1(+);
或
select col1[,col2,col3....] from table_name1 left join table_name2 on tba1.col1=tab2.col1;
示例1
使用(+)写法,(+)在右表上
示例二
使用 left join on 关键词
1.2.4 右关联查询
说明
1.哪个表名在前,哪个表就是左边,在后面的为右表
2. 右表的全部信息都会查询出来,左表的信息只有关联上的信息才会查询到,左表没有关联上的信息,则会显示为空,关键词 right join,
也可以用(+)来关联
语法
select col1[,col2,col3....] from table_name1,table_name2 where tba1.col1(+)=tab2.col1;
或
select col1[,col2,col3....] from table_name1 right join table_name2 on tba1.col1=tab2.col1;
示例1
使用(+)写法,(+)在左表上
示例二
使用 right join on 关键词
1.2.5 内连接
说明
内连接实际不分左右表
内连接只会显示两个表能关联上的结果,没有关联上的数据不会显示
内连接使用inner join关键词
语法
select col1[,col2,col3....] from table_name1 [inner] join table_name2 on tba1.col1=tab2.col1;
示例
1.2.6 全连接
说明
全连接不分左右表
全连接会显示两个表的所有结果,没有关联上的数据则会显示为空
全连接使用full join关键词
语法
select col1[,col2,col3....] from table_name1 full join table_name2 on tba1.col1=tab2.col1;
1.2.7
使用
exists
和
not exists
查询
说明
使用 exist
可以查询主表数据存在附表中的结果
使用 not exist
可以查询主表数据不在附表中的结果
语法
select * from tab1 where [not] exists(select 1 from tab2 where tab1.col=tab2.col);
示例1
查询部门表部门标号在雇员表中的数据
示例2
查询部门表部门标号不在雇员表中的数据
二
、DML语句
Oracle
数据库的
DML
表数据的操作有三种:
1 insert
(插入)
2 update
(更新)
3 delete
(删除)
(为了避免更改掉原始的数据,所以我把emp复制了一份出来,表名为emp_new,表空没有数据。以下的用例都使用这张emp_new)
2.1 insert 语句使用
2.1.1 insert 基本用法
说明
1. 如果想要给表中添加数据的话,则需要使用insert into和values关键字来添加我们想要的数据
2. 可以选择要填充的字段名与值来插入数据
3. 也可以全表所有字段来插入数据
4. 在给定值的时候一定要注意值要符合表规定(比如字段类型,是否为空,是否唯一等等)
5.需要注意的是,在插入之后需要commit(提交)后才能永久的生效我们的操作。
语法
按照选定字段插入,values后面值的位置,对应前面字段的顺序,不指定的字段缺省都为空
insert into tab_name(col1[,col2,col3....]) values('value1'[,'value2','value3'....]);
插入表中全部值,这种写法需要注意的是,不能跳过字段,否则会串列
insert into tab_name values('value1','value2','value3'....);
示例1
按照指定字段插入值
示例2
插入所有字段
2.1.2 引用另一个表的结果插入
说明
可以将另一个表中的查询结果插入目标表,可以是选择字段插入,也可以是全字段列的插入,但是需要注意的是无论哪种方式,都要注意表限制和字段顺序,以及两个表值的个数数量要一致。
语法
insert into tab1(col1[,col2,col3....]) select col1[,col2,col3....] from tab2;
或
insert into tab1 select * from tab2;
示例1
按字段插入另一个的结果
(该插入是引用了emp表的雇员编号为7902的查询结果)
示例2
引用另一个表中的全部字段插入
2.2 update语句使用
2.2.1 update 基本用法
说明
1. 如果想要在表中修改已存在数据的话,则需要使用
update set关键字来修改我们想要的数据
2. 更新是针对列修改的
3. 如果想修改某行或者某几行的某一列,则必须加条件否则会把整个表得该列都更新成一样的
4. 在给定更新值也必须符合到表限制(比如字段类型,是否为空,是否唯一等等)
5.需要注意的是,在更新之后需要commit(提交)后才能永久的生效我们的操作。
语法
update tab
set col1='xxx'
[where col1='xxx'......];;
示例1
无条件更新整个列
(将所有人的奖金都加100。需要注意的是,由于奖金字段(comm)的类型是数字的,而且值为null,所以数字类型为null值默认不会更新,但是字符格式的不存在这种情况)
示例2
按照条件更新值
(将所有人奖金为空的人的奖金更新成为200。需要注意的是:更新数字格式字段值为null的情况,必须指定要更新字段值为null)
2.2.2 update
高级用法
说明
1.更新还可以同时更新多个值,通过逗号隔开
2.还可以引用另一个表的查询结果来更新
多值更新
语法
update tab
set col1='xxx',col2='xxxx'
[where col1='xxx'......];
示例
同时更新mgr和sal值
引用查询结果
语法
update tab1
set col1=(select col1 from tab2 where tab1.col=tab2.col)
[where col1='xxx'......];
示例
根据emp表中查询得到dept字段和mgr字段结果更新emp_new表中的deptno字段和mgr字段
2.2 delete语句使用
2.2.1
delete基本用法
说明
1. 如果想要在表中删除已存在数据的话,则需要使用
delete关键字来删除我们不想要的数据
2. 删除数据可以不卡条件直接删除表中所有的数据
3. 也可以卡条件字段来删除特定的数据
4.需要注意的是,在删除之后需要commit(提交)后才能永久的生效我们的操作。
5.特别要强调的是,要在删除前把delete改成select 执行下,确保查询到的结果就是要删除的正确数据,防止误删除事件发生
语法
delete from tab [where col1='xxx'......];
示例
按条件删除
删除部门编号为null的数据
删除表中全部数据
今天想表达的关于技术的东西都写完了,说些题外话,这是我写的第一遍博客,就挑选了入门的基础知识来帮助入门oracle的朋友们供一个思路算是抛砖引玉吧。我个人能力有限,写的东西水平业有限,不足之处还望大家提出来,在日后的博客中改进,然后希望日后能跟大家多多交流共同学习进步。