文章简介
在学习关系型数据库的时候,教材上的数据库使用的是Oracle关系型数据库,而我因为其它原因,使用的是MySQL数据库。从数据库的类型上来讲,两者都是关系型数据库,数据的存取模式上没太大的差别,但是毕竟是两个不同的关系型数据库,Oracle的功能要更强大一些。毕竟一个是免费的一个是有付费版本的。本文就MySQL数据为例,就我学习期间总结的资料,总结一些MySQL数据库中的DDL、DML、DCL语句。
DDL(Data Definition Language数据库定义语言)
数据库定义语言,主要用于数据库中对数据,数据表等的定义。主要涉及create语句,alter语句,drop语句等。例如:
创建基本表
create table allbook(
bookid char(20),
ISBN char(20),
borrowed char(4),
borrowedinfo char(50)
); //这里没有在创建表的时候进行完整性约束,因为后面讲如何使用alter语句添加约束,实际上可以在创建表的时候就进行完整性约束,这样会更方便。
修改基本表
alter table tablename add column columnname varchar(20) not null after beforecolumnname; //在指定字段后面插入列
ALTER TABLE tb_article MODIFY COLUMN NAME VARCHAR(50); //修改字段类型和长度
ALTER TABLE tb_article CHANGE name1 name2 VARCHAR(30); //修改字段名
添加完整性约束
alter table test add primary key(test_no); //主键约束
alter table test add unique(test_student); //unique约束
alter table test drop primary key; //删除该表中的主键
alter table test add foreign key (test_no) references test1(test_no);
alter table test add constraint N1 foreign key (test_no) references test1(test_no); //添加外键约束
alter table test drop foreign key 外键约束名; //删除外键约束
alter table test modify test_student char(10) not null;