MySQL DDL数据定义语言

库和表的管理

一、库的管理

	创建:CREATE DATABASE IF NOT EXISTS 库名;
	修改:RENAME DATABASE books TO 新库名;
	删除:DROP DATABASE IF EXISTS 库名;

二、表的管理

	创建: create table 表名(
				列名 列的类型【(长度) 约束】,
				列名 列的类型【(长度) 约束】,
				......
			)
			
	修改:
		列名:ALTER TABLE 表名 CHANGE COLUMN 列名 新列名 列类型;
		
		列的类型:ALTER TABLE 表名 MODIFY COLUMN 列名 列类型;
		
		添加新列:ALTER TABLE 表名 ADD COLUMN 列名 列类型;
		
		删除列:ALTER TABLE book_author DROP COLUMN 列名;
		
		修改表名:ALTER TABLE 表名 RENAME TO  新表名;
		
	删除:DROP TABLE 表名;
	
	复制:
		仅复制表结构:CREATE TABLE 复制后的表名 LIKE 被复制的表名;
		
		复制表的结构和数据:CREATE TABLE 复制后的表名 
						  SELECT * FROM 被复制的表名;
		
		只复制部分数据:CREATE TABLE 复制后的表名
					  SELECT 某列
					  FROM 被复制的表名
					  WHERE 列名=?;
		只复制某些字段:CREATE TABLE 复制后的表名
						SELECT 字段名,字段名
						FROM 被复制表名
						WHERE true;

常见约束

含义:一种限制,用于限制表中的数据,为了保证表中的数据的准确和可靠性

	六大约束
	NOT NULL:非空,用于保证该字段的值不能为空
	
	DEFAULT:默认,用于保证该字段有默认值
	
	PRIMARY KEY:主键,用于保证该字段的值具有唯一性,并且非空
	
	UNIQUE:唯一,用于保证该字段的值具有唯一性,可以为空
	
	CHECK:检查约束【mysql中不支持】
	
	FOREIGN KEY:外键,用于限制两个表的关系,用于保证该字段的值必须来自于主表的关联列的值在从表添加外键约束,用于引用主表中某列的值
	

列级约束

		CREATE TABLE 表名(
			列名 类型 PRIMARY KEY,#主键
			列名 类型 NOT NULL UNIQUE,#非空
			列名 类型 CHECK(gender='男' OR gender ='女'),#检查
			列名 类型 UNIQUE,#唯一
			列名 类型 DEFAULT  18,#默认约束
			列名 类型 REFERENCES major(id)#外键
		);

表级约束

		CREATE TABLE stuinfo(
			列名 类型,
			列名 类型,
			列名 类型,
			列名 类型,
			
			CONSTRAINT pk PRIMARY KEY(列名),#主键
			CONSTRAINT uq UNIQUE(列名),#唯一键
			CONSTRAINT ck CHECK(列名 ='男' OR 列名  = '女'),#检查
			CONSTRAINT fk_stuinfo_major FOREIGN KEY(majorid) REFERENCES major(列名)#外键
			
		);

修改表示添加约束

		1、添加列级约束
		alter table 表名 modify column 字段名 字段类型 新约束;
		
		2、添加表级约束
		alter table 表名 add 【constraint 约束名】 约束类型(字段名) 【外键的引用】;

标识列

又称为自增长列
含义:可以不用手动的插入值,系统提供默认的序列值

特点:
1、标识列必须和主键搭配吗?不一定,但要求是一个key
2、一个表可以有几个标识列?至多一个!
3、标识列的类型只能是数值型
4、标识列可以通过 SET auto_increment_increment=3;设置步长可以通过 手动插入值,设置起始值
创建表时设置标识列

	CREATE TABLE tab_identity(
		id INT,
		NAME FLOAT UNIQUE AUTO_INCREMENT,
	);
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值