一、DML数据操作语言  (DQL  select )

  主要用于检索、插入和修改数据库信息。它是最常用的SQL命令,如INSERT(插入)、UPDATE(更新)、SELECT(选择)、DELETE(删除)。

1、INSERT插入语句:

  语法

  INSERT INTO tablename[column1[,column2...]]

  VALUES (value1[,value2...]);

  说明:

  INSERT INTO:为插入的关键字。

  tablename:表示要插入的表。

  column1:可选参数,表示要插入的列,多个列使用,分隔。

  values(value1..):插入的值,这里的value1,必须和前面的列相对应,如果不写列,则必须和表的结构一致。

  例:  

--创建学员信息表,并添加约束 CREATE TABLE stuinfo (   stuName VARCHAR2(20) NOT NULL CONSTRAINT pk_name PRIMARY KEY,   stuPass VARCHAR2(20) NOT NULL CONSTRAINT ck_pass CHECK (LENGTH(stupass) > 3),   stuAge NUMBER(3,0) NOT NULL CONSTRAINT ck_age CHECK (stuage>18),   birthday DATE DEFAULT SYSDATE )

             向学员信息表中插入数据  

--向学生表中插入一条记录 INSERT INTO stuinfo(stuname,stupass,stuage,birthday) VALUES ('张三','123123',20,DEFAULT)
--添加自定义日期类型的数据 INSERT INTO stuinfo VALUES ('李四','123456',25,to_date('1999-9-20','yyyy-Mm-dd'))

  注意事项:

  1)插入的列必须和插入的值一一对应,包括数据类型,个数,顺序必须要全一致。

  2)如果数据表中包含了默认值,则可以使用default关键字插入默认值。

  3)插入的数据必须满足数据约束。否则插入失败。

  4)插入的列可以省略,但是必须按照表中列的顺序插入数据。

  5)通过to_date完成对日期函数数据的添加。

  6)插入字符串类型必须使用'包含起来。

  插入多行记录:

    (1、insert..into...select...生成自定义数据

--一次插入多行数据,通过union关键字拼接查询 INSERT INTO stuinfo(stuname,stupass,stuage,birthday) SELECT '王五','888888',20,to_date('1999-8-8','yyyy-Mm-dd') FROM dual UNION SELECT '赵六','666666',25,to_date('195-8-20','yyyy-Mm-dd') FROM dual

              将多个查询结果拼接起来一次插入数据库,这里查询的类型数据必须和插入的数据类型和顺序完全一致。

    (2、insert..into...select...将已经存在表的记录插入到新表中

INSERT INTO stuinfo (stuname,stupass,stuage,birthday) SELECT NAME,pass,age,SYSDATE FROM backuser

                将查询结果插入到一个已经存在的表中,如果表不存在则报错。

    (3、select...into...

--将查询到的数据生成一个新的表

CREATE TABLE backuser AS SELECT stuname,stupass,stuage,birthday FROM stuinfo

                  将查询到的结果插入到一张新表中,表必须不存在,如果存在则报错。

2.update 语句(更新)

语法:

  UPDATE table SET 列名1=‘ 值’,列名2=‘ 值’……

    where 条件;

  例子: 

--将赵六的密码修改为8个6,然后将出生日期改为1989-5-20
UPDATE stuinfo
SET stupass='666666',
birthday=to_date('1989-5-20','yyyy-MM-dd') --插入日期需要进行格式转换
WHERE stuname = '赵六' --指定修改数据的条件,条件不满足不执行任何操作
commit; --执行完毕后自动进行提交

 

  注意:

  1)修改的数据同样必须满足数据库中的约束。

  2)修改后的数据如果在PLSQL中需要使用comit提交事务,数据才算修改成功。

  3)修改后的条件需要跟上,否则是修改表中所有记录。

3、删除语句

  1)DELETE语法:

  DELETE [FROM] tablename

  [WHERE condition];

  说明:

  DELETE [FROM]:为删除的关键字。FROM可以省略不写。

  tablename:要删除数据的表。

  where condition:要删除数据的条件,不写则删除表中所有记录

例:

delete 表名 where 列名=‘值  a’;  --删除列名为 a 的一行数据

  delete  表名;  --删除该中所有的信息

  

  2)TRUNCATE table 清空表

  语法:

  truncate tablename;

  说明:

  truncate:清空关键字。

  tablename:要清空的表明。

        例:  

TRUNCATE TABLE es_product;   --清空 es_product 表中的所有信息

  

delete和truncate的区别:

  a)truncate快速删除记录并释放空间,不适用事务处理,因此无法回滚,而delete命令可在执行删除之后,通过rollback撤销删除。

  b)truncate将删除表中的所有记录,而DELETE不仅可以删除表中的记录,还可以通过where条件删除表中的部分数据。

DML 数据操控语言的更多相关文章

  1. 6.1课堂笔记—DML(数据操作语言),DQL查询语句

    一.DML(数据操作语言) InnoDB MyISAM 支持事务 不支持事务 不支持全文索引 支持全文索引 支持外键约束 不支持 命令查看默认存储引擎 show variables like '%st ...

  2. DML数据操作语言

    DML数据操作语言 用来对数据库中表的数据记录进行更新.(增删改) 插入insert -- insert into 表(列名1,列名2,列名3...) values (值1,值2,值3...):向表中 ...

  3. DML数据操作语言之谓词,case表达式

    谓词:就是返回值是真值的函数. 前面接触到的“>” “<” “=”等称为比较运算符,它们的正式名称就是比较谓词.因为它们比较之后返回的结果是真值. 由于谓词 返回的结果是一个真值 ,即tr ...

  4. DML数据操作语言之增加,删除,更新

    1.数据的增加 数据的增加要用到insert语句  ,基本格式是: insert into <表名> (列名1,列名2,列名3,......) values (值1,值2,值3,..... ...

  5. DML数据操作语言之常用函数

    所谓函数,就是输入某一值,得到相应的输出结果的功能.相当于一个加工厂,给了原料,最终产出成品. 其中原料 就是参数(parameter). 产品 就是返回值. 函数大致可以分为以下五个种类: 算术函数 ...

  6. DML数据操作语言之复杂查询

    1.视图(View) 我们知道,在关系型数据库中,用来保存实际数据记录的是数据表.和表同等概念也是用来保存东西是:视图. 但是数据表是用来保存实际数据记录的,而视图是用来保存常用select语句的. ...

  7. DML数据操作语言之查询(二)

    当我们查询出了N条记录之后 ,我们知道一共是几条记录,或者这些记录某一字段(列值)的最大值,最小值,平均值等,就可以使用聚合函数. 1.聚合函数 聚合函数会将null 排除在外.但是count(*)例 ...

  8. DML数据操作语言之查询(一)

    1.select语句基础 基本语句格式:  select <列名>,.... from <表名>; select子句中列举出希望从表中查询出的列的名称,from子句则指定了选取 ...

  9. MySQL SQL DML (数据操作语言)

    包括 SELECT, UPDATE, DELETE, INSERT SELECT 从数据库表中获取数据 用法 SELECT name FROM students; SELECT name,age FR ...

随机推荐

  1. c++字符串机理

    在windows编程中,由于编码方式的不同和c与c++的不同而造成了许多复杂的有关字符串之间的转换 首先,windows编码方式有ANSCLL和UNICODE,前者是单字符的,后者是双字符的. 然后, ...

  2. 妙用缓存调用链实现JS方法的重载

    来自于我的博客http://sweets.cf/,转载注明出处 1.什么是方法重载 方法重载是指在一个类中定义多个同名的方法,但要求每个方法具有不同的参数的类型或参数的个数. 简而言之就是:方法重载就 ...

  3. [转]C语言文件输入/输出ACM改进版(freopen函数)

    C语言文件输入/输出ACM改进版(freopen函数) 2009年5月27日 10:379,457 浏览数发表评论阅读评论   文章作者:姜南(Slyar) 文章来源:Slyar Home (www. ...

  4. Jquery基础:append、prepend、after、before、appendTo的区别

    append() 是在被选元素的结束标签前面(即改被选元素的内部)插入指定内容. after() 是在被选元素的结束标签后面(即该被选元素的外部)插入指定的内容. appendTo() 仍然是在被选元 ...

  5. Rstudio安装

    1.https://www.r-project.org/下载R语言(注意32位还是46位系统). 2.安装R,尽量默认安装路径,安装路径不要有中文. 3.https://www.rstudio.com ...

  6. c#委托把方法当成参数

    //定义委托,它定义了可以代表的方法的类型 public delegate void GreetingDelegate(string name); /// <summary> /// 用英 ...

  7. spring中propertyplaceholderconfigurer简介

    Spring的框架中为您提供了一个 BeanFactoryPostProcessor 的实作类别: org.springframework.beans.factory.config.PropertyP ...

  8. uva331 - Mapping the Swaps

    Mapping the Swaps Sorting an array can be done by swapping certain pairs of adjacent entries in the ...

  9. PL/pgSQL学习笔记之四

    http://www.postgresql.org/docs/9.1/static/plpgsql-structure.html 39.2. PL/pgSQL 的结构 PL/pgSQL是一种块式结构的 ...

  10. Codeforces Round #253 (Div. 1) A. Borya and Hanabi 暴力

    A. Borya and Hanabi Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/contest/442/p ...