DDL与DML语句

1. DDL语句

SQL语句:结构化查询语句,使用SQL与数据库“沟通”,完成相应的数据库操作。

l DDL:数据定义语言,用来维护数据库对象

1.1 创建表

? CREATE:创建表

演示:创建员工表


CREATE TABLE employee(

id NUMBER(4),

name VARCHAR2(20),

gender CHAR(1),

birth DATE,

salary NUMBER(6,2),

job VARCHAR2(30),

deptno NUMBER(2)

);

? DESC:查看表的数据结构

演示:查看创建的员工表


DESC employee;

? DEFAULT:设置默认值

可以通过DEFAULT子句给列指定默认值

演示:建表时给gender默认值为”M”


CREATE TABLE emptest(

id NUMBER(4),

name VARCHAR2(20),

gender CHAR(1) DEFAULT ‘M‘,

birth DATE

);

? NOT NULL:非空

默认情况下,任何列都允许有空值。非空(NOT NULL)是一种条件约束,用于确保字段值不为空,当某个字段被设置了非空约束条件,这个字段中必须存在有效值,即:当执行插入数据操作时,必须提供这个列的数据;当执行更新操作时,不能给这个列的值设置为NULL。

演示:创建员工表设置那么为非空字段


CREATE TABLE emptest(

id NUMBER(4) ,

name VARCHAR2(20) NOT NULL,

gender CHAR(1) DEFAULT ‘M‘,

birth DATE

);

1.2 修改表

? RENAME:修改表名

演示:修改表名


RENAME emptest to testemp;

? ALTER TABLE的ADD子句

增加列,列只能增加在最后,不能插入现有的列中。

演示:在testemp表下面增加hiredate列,并将默认值设置为当前时间


ALTER TABLE testemp ADD(hiredate DATE DEFAULT sysdate);

? ALTER TABLE的DROP子句

删除列,删除字段需要从每行中删掉该字段占据的长度和数据,并释放在数据块中占据的空间,如果表记录比较大,删除字段可能需要比较长的时间。

演示:删除testemp表下的hiredate


ALTER TABLE testemp DROP (hiredate);

? DROP删除表


DROP TABLE emptest;

? ALTER TABLE的MODIFY子句

修改列,使用MODIFY可以改变表中列的数据类型、长度和默认值,注意这种修改仅对以后插入的数据有效。另外如果表中已经有数据的情况下,把长度由大改小,有可能不成功,比如原来类型是VARCHAR2(100),其中已经存放了100字节长度的数据,如果改为80字节,则不会修改成功。

演示:修改testemp表中name的长度为30


ALTER TABLE testemp MODIFY(name VARCHAR2(30));

2. DML语句

l 用于增删改表中数据,DML是伴随TCL事务控制的。

? INSERT

INSERT语句用来给数据表增加记录,每次增加一条记录。所有的DML操作,需要再执行事务提交语句COMMIT才算真正确认了此操作。

演示:想testemp中插入一条记录


INSERT INTO testemp (id,name,gender) VALUES (1,‘张三‘,‘M‘);

COMMIT;

插入数据时忽略字段则是全列插入,顺序不能错误,如下:


INSERT INTO testemp VALUES (10,‘李四‘,‘F‘,sysdate);

COMMIT;

? UPDATE

更新表中的记录,需要配合WHERE子句使用,否则全表的数据都会被更新。

演示:更新testemp表中张三的ID为2


UPDATE testemp SET id=2 WHERE name=‘张三‘;

COMMIT;

同时修改两个类型:


UPDATE testemp SET id=5,name=‘王五‘ WHERE name=‘李四‘;

COMMIT;

? DELETE

删除表中的记录,和UPDATE一样,需要配合WHERE子句使用,不然会将全表数据删除。

演示:将testemp表中id为2的记录删除


DELETE FROM testemp WHERE id=2;

清空表:


DELETE FROM testemp;

时间: 2024-11-05 17:24:29

DDL与DML语句的相关文章

jdbc java数据库连接 3)Statement接口之执行DDL和DML语句的简化

上一章的代码中,可以发现,jdbc执行DDL和DML有几个步骤都是一样的: 1)执行语句开始时,创建驱动注册对象.获取连接的数据库对象.创建Statement对象 1 // 创建驱动注册对象 2 Class.forName("com.mysql.jdbc.Driver"); 3 4 // 获取连接的数据库对象 5 Connection conn = DriverManager.getConnection(url, user, 6 password); 7 8 // 创建Statemen

入门MySQL——DML语句篇

前言:? 在上篇文章中,主要为大家介绍的是DDL语句的用法,可能细心的同学已经发现了.本篇文章将主要聚焦于DML语句,为大家讲解表数据相关操作. 这里说明下DDL与DML语句的分类,可能有的同学还不太清楚. DDL(Data Definition Language):数据定义语言,用于创建.删除.修改.库或表结构,对数据库或表的结构操作.常见的有create,alter,drop等. DML(Data Manipulation Language):数据操纵语言,主要对表记录进行更新(增.删.改)

JAVA-Unit01: 数据库原理 、 SQL(DDL、DML)

Unit01: 数据库原理 . SQL(DDL.DML) SQL语句是不区分大小写的,但是行业里习惯将关键字与分关键字用大小写岔开以提高可读性. SELECT SYSDATE FROM dual DDL语句 数据定义语言 用于操作数据库对象 数据库对象有:表,视图,索引,序列 创建表: CREATE TABLE employee( id NUMBER(4), name VARCHAR2(20), gender CHAR(1), birth DATE, salary NUMBER(6,2), jo

使用DML语句【weber出品必属精品】

DML语句包含以下语法: INSERT:往一个表中增加新行 DELETE:从一个表中删除掉现有的行 UPDATE:更改一个表中现有的行 INSERT语句语法:INSERT INTO TABLE(COLUMN1,COLUMN2,....) VALUES(VAL1,VAL2,...)使用这种方法只能一次插入一行数据 插入包含每一个列值的新行,按缺省顺序列出表中所有的列值. 创建带有结构的空表 SQL> create table t as select * from emp where 1=2;---

DDL、DML和DCL的区别与理解

DML.DDL.DCL区别 . 总体解释: DML(data manipulation language): 它们是SELECT.UPDATE.INSERT.DELETE,就象它的名字一样,这4条命令是用来对数据库里的数据进行操作的语言 DDL(data definition language): DDL比DML要多,主要的命令有CREATE.ALTER.DROP等,DDL主要是用在定义或改变表(TABLE)的结构,数据类型,表之间的链接和约束等初始化工作上,他们大多在建立表时使用 DCL(Da

7.PL_SQL——在PL_SQL程序中内嵌查询语句、DML语句和事物处理语句

在PL/SQL中可以使用的SQL语句主要有以下几类: SELECT 查询语句,DML语句,Transaction 事物处理语句,本文将对这几类语句在PL/SQL中的用法逐一介绍. 一.查询语句-SELECT SELECT 语句用来查询一条或多条语句.虽然SELECT 语句也属于DML语句,但SELECT是只读的,所以单独列出. 在PL/SQL中使用SELECT 语句的格式如下:   SELECT select_list INTO {variable_name[,variable_name]...

DDL、DML和DCL的理解

一.DDL 1.DDL的概述 DDL(Data Definition Language 数据定义语言)用于操作对象和对象的属性,这种对象包括数据库本身,以及数据库对象,像:表.视图等等,DDL对这些对象和属性的管理和定义具体表现在Create.Drop和Alter上.特别注意:DDL操作的“对象”的概念,”对象“包括对象及对象的属性,而且对象最小也比记录大个层次.以表举例:Create创建数据表,Alter可以更改该表的字段,Drop可以删除这个表,从这里我们可以看到,DDL所站的高度,他不会对

DDL、DML和DCL的比较【引用学习】

1.DDL 1-1.DDL的概述 DDL(Data Definition Language 数据定义语言)用于操作对象和对象的属性,这种对象包括数据库本身,以及数据库对象,像:表.视图等等,DDL对这些对象和属性的管理和定义具体表现在Create.Drop和Alter上.特别注意:DDL操作的“对象”的概念,”对象“包括对象及对象的属性,而且对象最小也比记录大个层次.以表举例:Create创建数据表,Alter可以更改该表的字段,Drop可以删除这个表,从这里我们可以看到,DDL所站的高度,他不

内外连接、组函数、DDL、DML和TCL

前言 cross join ,是笛卡尔积:nature join 是自然连接. 正文 内外连接 inner join inner join 的inner可以省略. 内连接 在一个表中能够找到在另一个表中与之对应的记录,来组成新的记录显示出来,舍弃表中在另一个表中没有对应记录的记录. 等值连接 一个表中的某个字段是另一个表的外键 例如.emp表和dept表存在多对一的关联关系,由外键字段deptno来维护,即emp表来主动维护这一关系. 非等值连接 between and 来实现非等值连接: se