插入,更新,删除数据

oracle提供了功能丰富的数据库管理语句

包括有效的向数据库中插入数据的insert语句

更新数据的update语句

以及当数据不再使用时删除数据的delete语句

更改数据之后一定要使用提交操作,否则只保存在内存中,别人无法查看到更改

  • Rollback;

    • 回滚
  • commit;
    • 提交

1插入数据

准备表

SQL> create table person(
2 id number(9) not null,
3 name varchar2(40) not null,
4 age number(9) not null,
5 info varchar2(50) null,
6 primary key(id)
7 );
表已创建。

1.1表的所有字段插入数据

向表中所有宇段插入值的方法有两种

  • 一种是指定所有字段名 ,
  • 另一种是完全不指定字段名

语法

INSERT INTO table_name (column_list) VALUES (value_list);

1指定所有字段名

插入数据时,不需要按照表定义的顺序插入,只要保证值的顺序与列宇段的顺序相同就可以

SQL> insert into person(id,name,age,info)
2 values(1,'Green',21,'lawyer'); 已创建 1 行。

2完全不指定 字段名

值列表为每一个字段列指定插入值,并且这些值的顺序必须和person表中字段定义的顺序相同

SQL> insert into person
2 values(2,'Mary',24,'Musician'); 已创建 1 行。

当需要插入空值时,可以使用null关键字或者''

SQL> insert into person
2 values(3,'meditation',24,null); 已创建 1 行。

1.2为表的指定字段插入数据

在person表中,插入一条新记录,name值为Willam,age为20

SQL> insert into person(id,name,age)
2 values(4,'Willam',20); 已创建 1 行。

1.3同时插入多行数据

SQL> insert into person(id,name,age)
2 select 5,'Harry',21 from dual
3 union all
4 select 6,'harriet',19 from dual; 已创建2行。

1.4将查询结果插入到数据中

语法

insert into table_name1(column_list1)
select (column_list2) from table_name2 where (condition)
  • table_name1 指定待插入数据的表
  • column_list1 指定待插入表中要插入数据的那些列
  • table_name2 指定插入数据是从哪个表中查询出来的
  • column_list2 指定数据来源表的查询列.该列表必须和column_list1 列表中的字段个数相同,数据类型相同
  • condition 指定 SELECT 句的查询条件

准备person_old表

SQL> create table person_old(
2 id number(9) not null,
3 name varchar2(40) not null,
4 age number(9) not null,
5 info varchar2(50) null,
6 primary key(id)
7 );
表已创建。

插入数据

SQL> insert into person_old(id,name,age)
2 select 7,'Evans',23 from dual
3 union all
4 select 8,'Dale',29 from dual; 已创建2行。

将person_old中的两条数据添加到person中

SQL> insert into person(id,name,age)
2 select id,name,age from person_old; 已创建2行。
SQL> select id,name,age from person;

        ID NAME               AGE
---------- ----------- ----------
1 Green 21
2 Mary 24
3 meditation 24
4 Willam 20
5 Harry 21
6 harriet 19
7 Evans 23
8 Dale 29
  • 从结果可以看到,person表中多了两条记录
  • id列一般是自增的主键,在插入时要保证该字段的唯一性
  • 如果不能确定,可以插入的时候忽略该字段,只插入其他字段的值

2更新数据

oracle中使用update语句更新表中的记录,

可以更新特定的行,或者更新所有的行

语法

update table_name
set column_name1=value1,...column_namen=valuen
where (condition);

更新id值为6的记录,将age字段改为25,将name字段改为LiMing

SQL> update person
2 set age=25,name='LiMing'
3 where id=6; 已更新 1 行。

更新age值为19~23的记录,将info字段值改为student

SQL> update person
2 set info='student'
3 where age between 19 and 23; 已更新4行。
SQL> select * from person;

        ID NAME                 AGE INFO
---------- ------------- ---------- ----
1 Green 21 student
2 Mary 24 Musician
3 meditation 24
4 Willam 20 student
5 Harry 21 student
6 LiMing 25
7 Evans 23 student
8 Dale 29

2.2联表更新

将person表和person_old表中id列相同的数据的 info列改为person表的info列

SQL> select * from person_old;

        ID NAME                    AGE INFO
---------- ---------------- ---------- -----------
7 Evans 23
8 Dale 29

update

SQL> update person_old p1
2 set info=(select info from person p2 where p1.id=p2.id)
3 where exists(select 1 from person p2 where p1.id=p2.id); 已更新2行。
SQL> select id,name,info from person_old;

        ID NAME          INFO
---------- ------------- ---------
7 Evans student
8 Dale SQL>

merge into

将person表和person_old表中id列相同的数据的 info列改为person表的info列

SQL> Rollback;
回退已完成。 SQL> select * from person_old;
ID NAME AGE INFO
---------- ------- ---------- ------
7 Evans 23
8 Dale 29
SQL> merge into person_old p1
2 using person p2
3 on(p1.id=p2.id)
4 when matched then
5 update
6 set
7 p1.info=p2.info; 2 行已合并。
SQL> select * from person_old;

        ID NAME        AGE INFO
---------- -------- ------ ----
7 Evans 23 student
8 Dale 29
SQL>
语句 描述
merge into: 关键字,后跟主表表名
using: 用,后跟源数据,可以是一个表,也可以是一个结果集
on: 关键字, 后面括号内跟关联条件;
when matched then: 即当满足on后条件时,执行更新操作,即后面跟的update;
when not matched then: 即当on后的条件不满足,要执行的操作

3删除数据

delete语句允许使用where子句指定删除条件

3.1删除单行数据

SQL> delete from person
2 where id=7;
已删除 1 行。
SQL> select * from person where id=7;
未选定行

3.2删除多行数据

SQL> delete from person
2 where info is null;
已删除3行。
SQL> select * from person where info is null;
未选定行
SQL> delete from person
2 where id between 4 and 8;
已删除2行。
SQL> select * from person
2 where id=4;
未选定行

3.3删除全部数据

SQL> select count(1) from person;
COUNT(1)
----------
2
SQL> delete from person;
已删除2行。
SQL> select count(1) from person;
COUNT(1)
----------
0

3.4truncate清除表中所有数据

SQL> Rollback;
回退已完成。 SQL> select count(1) from person;
COUNT(1)
----------
8
SQL> truncate table person;
表被截断。 SQL> select count(1) from person;
COUNT(1)
----------
0

3.5truncate和delete区别

  1. delete是DML语句,需要提交; truncate 是DDL语句,不需要提交;
  2. delete可以删除一行或者多行数据,truncate是针对全表数据;
  3. 当数据量比较大时,delete会比较慢,因为要写日志,方便数据恢复.truncate则很快,因为只写少量日志,因此也难以恢复;

oracle插入,更新,删除数据的更多相关文章

  1. MariaDB 插入&更新&删除数据(8)

    MariaDB数据库管理系统是MySQL的一个分支,主要由开源社区在维护,采用GPL授权许可MariaDB的目的是完全兼容MySQL,包括API和命令行,MySQL由于现在闭源了,而能轻松成为MySQ ...

  2. 我的MYSQL学习心得(八) 插入 更新 删除

    我的MYSQL学习心得(八) 插入 更新 删除 我的MYSQL学习心得(一) 简单语法 我的MYSQL学习心得(二) 数据类型宽度 我的MYSQL学习心得(三) 查看字段长度 我的MYSQL学习心得( ...

  3. sqlserver 插入 更新 删除 语句中的 output子句

    官方文档镇楼: https://docs.microsoft.com/zh-cn/previous-versions/sql/sql-server-2008/ms177564(v=sql.100) 从 ...

  4. MySQL基本SQL语句之数据插入、删除数据和更新数据

    一.INSERT插入数据: 方法一:批量插入 基本语法: INSERT INTO tb_name (col1, col2, ...) VALUES (val1, val2, ...)[,(val1, ...

  5. Oracle恢复已删除数据

    Oracle恢复已删除的数据,主要有两种方法:SCN和时间戳. 一.通过SCN恢复删除且已提交的数据 1.获得当前数据库的scn号 select current_scn from v$database ...

  6. oracle 恢复table删除数据 恢复package(使用闪回)

    好久没写东西了,今天写一篇凑个数吧,来公司一年多了,感觉自己到了一个小瓶颈期了. 以前每天很多新东西,都是忙着学,感觉没时间写博客总结一下,大部分都是写笔记,现在又是没东西可以写,每天干着95%都是重 ...

  7. Hibernate更新删除数据后,再查询数据依然存在的解决办法

    删除数据后,重新查询了数据库,DB中记录已经删除了,但是数据依然能查询到,网上都说是Hibernate的缓冲问题. 我对session进行了clear,flush,并且在事务和查询中都对session ...

  8. Mysql添加更新删除数据-表

    例如 此处拥有一个表名为 uuser 为表添加新数据 ,'); ,'); ,'); 假如只想添加uid和uname ,'小张'); 那么pas自动填充为NULL. 为表更新数据 这里把小王的pas改成 ...

  9. MySQL 向表中插入、删除数据

    一.向表中插入一条信息 1.查看表中的数据 mysql> SELECT * FROM user; +----+---------+----------+ | id | account | pas ...

随机推荐

  1. 【从刷面试题到构建知识体系】Java底层-synchronized锁-2偏向锁篇

    上一篇通过构建金字塔结构,来从不同的角度,由浅入深的对synchronized关键字做了介绍, 快速跳转:https://www.cnblogs.com/xyang/p/11631866.html 本 ...

  2. SpringCloud之Nacos服务发现(十七)

    一 Nacos简介 Nacos是以服务为主要服务对象的中间件,Nacos支持所有主流的服务发现.配置和管理. Nacos主要提供以下四大功能: 服务发现与服务健康检查 Nacos使服务更容易注册自己并 ...

  3. 务必收藏备用:.net core中通过Json或直接获取图形验证码(数字验证码、字母验证码、混合验证码),有源代码全实战demo(开源代码.net core3.0)

    很多人写的博客大家看了会一知半解,不知道怎么用,应该引用什么类库或者代码不全,这样很多小白很是头疼,尤其是尝新技术更是如此.我们这边不止告诉你步骤,而且还提供开源demo.随着时间的推移,我们的dem ...

  4. Idea导入Web项目并发布到Tomcat

    Idea导入现有的Web项目并发布到Tomcat,发现Tomcat没有自动发布 问题: 导入一个Web项目时,idea并没有把他当成web,所以需要自己修改项目结构 1.导入项目 打开 File-&g ...

  5. 【Linux】【自学笔记】Linux下面docker安装mysql

    写在前面: 捣腾继续,之前把一个SpringBoot的程序安装在docker上面,参考链接:https://www.cnblogs.com/aki-stones/p/2019-11-01-note.h ...

  6. Cookie、Session、Token那点事儿

    1.什么是Cookie? Cookie 技术产生源于 HTTP 协议在互联网上的急速发展.随着互联网时代的策马奔腾,带宽等限制不存在了,人们需要更复杂的互联网交互活动,就必须同服务器保持活动状态(简称 ...

  7. STL.h

    最近老是被系统的一些STL卡到飞起,然后就手打了一个STL.h 库函数还没有打完,以后打新的还会再更,大家也可以使用,顺便帮我找一下bug,然后我再改进! template< typename ...

  8. [转载]2.6 UiPath循环嵌套的介绍和使用

    一.循环嵌套的介绍 一个循环体内又包含另一个完整的循环结构,就称之为循环嵌套.内嵌的循环中还可以嵌套循环,这就是多层循环,也叫做多重循环. 二.在UiPath中结合使用循环嵌套生成99乘法表 1.打开 ...

  9. 每天一道算法题-leetcode136-只出现一次的数字

    前言 打卡第一天 2019.10.26日打卡 算法,即解决问题的方法.同一个问题,使用不同的算法,虽然得到的结果相同,但是耗费的时间和资源是不同的.这就需要我们学习算法,找出哪个算法更好. 大家都知道 ...

  10. JDBD连接MySQL中的驱动与时区问题

    1.在进行jdbc与mysql连接的时候应注意,加载驱动的方式根据MySQL版本内容来说 有变化 5.7版本之前: String driver= "com.mysql.jdbc.Driver ...