当前位置:Gxlcms > 数据库问题 > MySQL的DDL和DML

MySQL的DDL和DML

时间:2021-07-01 10:21:17 帮助过:14人阅读

id NUMBER(4),

name VARCHAR2(20),

gender CHAR(1) DEFAULT ‘M‘,

birth DATE

);

设置列值非空NOT NULL

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

演示:在testemp表下面增加hiredate列,并将默认值设置为当前时间增加列,列只能增加在最后,不能插入现有的列中。

ALTER TABLE testemp ADD(hiredate DATE DEFAULT sysdate);

删除列 ALTER DROP

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

演示:删除testemp表下的hiredate

ALTER TABLE testemp DROP (hiredate);

修改列 ALTER MODIFY

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

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

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

 删除表DROP

DROP TABLE emptest;

二. DML语句

 用于增删改表中数据,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;

MySQL的DDL和DML

标签:授权   数据库   explain   sel   创建数据库   nbsp   rda   -o   eva   

人气教程排行