Mysql学习及笔记06--ddl语言、库的创建、修改、删除、表的管理创建、修改、删除、表的复制,常见数据类型,常见约束,修改表时添加、删除约束、标识列

1、ddl数据定义语言

库和表的管理
库的管理
创建,修改,删除

表的管理
创建:create
修改:alter
删除:drop

2、库的创建、修改、删除

创建
语法
create database books if not exists 库名

修改
一般不修改库,更改库的字符集如下
alter database books character set gbk;

删除
语法
drop database if exists 库名

3、表的管理

1、创建表
create table 表名(
列名 列的类型 【长度,约束等】,
列名 列的类型 【长度,约束等】,

CREATE TABLE book(
id INT,
bname VARCHAR(20),
price DOUBLE,
author_id INT,
publishdate DATETIME
)
CREATE TABLE author(
id INT,
author_name VARCHAR(20),
nation VARCHAR(10)
)

2、表的修改
语法
alter table 表名 add | drop | modify | change column 【列类型 约束】

  • 修改列名
ALTER TABLE book CHANGE publishdate pubDate DATETIME
  • 修改列的类型和约束
ALTER TABLE book MODIFY pubDate TIMESTAMP
  • 添加列

```java
ALTER TABLE book ADD annual DOUBLE
  • 删除列
ALTER TABLE book DROP annual 
  • 修改表名
ALTER TABLE book RENAME books

3、表的删除
语法
drop table 表名

DROP TABLE author

新建表的通用写法
drop table if exixts 旧表名
create table 表名();

4、表的复制

1、复制表的结构

CREATE TABLE copy LIKE author;

2、复制表的结构及数据

CREATE TABLE copy2 
SELECT * FROM author

复制部分条目

CREATE TABLE copy3
SELECT * FROM author WHERE nation='中国'

复制部分字段及条目

CREATE TABLE copy4 
SELECT author_name,nation
FROM author
WHERE nation='中国'

仅仅复制部分字段

CREATE TABLE copy4 
SELECT author_name,nation
FROM author
WHERE 1=2//即设置一个不可能为true的条件
5、常见数据类型

数值型:整形、小数(定点数,浮点数)
字符型:较短的文本(char,varchar),较长的文本:text,blob(较长的二进制文件类型)

1、整形

  • 如果不设置无符号(unsigned)还是有符号,默认是有符号
  • 如果超出整形范围会报警告(out of range)并插入临界值
  • 如果不设置长度(int(7))会有默认的长度
    2、小数
    略吧
6、常见约束

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

六大约束

  • not null:非空
  • default:默认约束,保证该字段有默认值
  • primary key:主键约束,保证该字段的值具有唯一性(同时非空)
  • unique:唯一约束,用于保证该字段的值具有唯一性,可以为空
  • check:检查约束【mysql中不支持】
  • foregin key:外键,用于限制两个表的关系,用于保证该字段的值,必须来自主表的关联列的值,从表添加外键约束,添加主表关键字段的值

添加约束的时机:
1、创建表时
2、修改表时

约束的添加分类
1、列级约束(添加列的时候设定的约束),支持6大约束,但外键约束没有效果

CREATE TABLE stuinfo(
id INT PRIMARY KEY,
stuname VARCHAR(20) NOT NULL,
gender CHAR(1) CHECK(gender='男' OR gender='女'),#默认检查约束
seat INT UNIQUE,
age INT DEFAULT 18,
majorid INT REFERENCES major(id)#外键约束
)
CREATE TABLE major(
id INT PRIMARY KEY,
majorname VARCHAR(20)
)

2、表级约束(不在列的后面,一般在表创建的尾部,对整个表进行约束),除了非空,默认,其他都支持
语法:在各个字段的最下面
CONSTRAINT 约束名 约束类型(字段名)

CREATE TABLE stuinfo(
id INT,
stuname VARCHAR(20),
gender CHAR(1),
seat INT,
age INT,
majorid INT,

CONSTRAINT pk PRIMARY KEY(id),#为id添加主键
CONSTRAINT qu UNIQUE(seat),#为seat添加唯一约束
CONSTRAINT ck CHECK(gender='男' OR gender='女'),#gender添加检查约束
CONSTRAINT fk_stuinfo_major FOREIGN KEY(majorid) REFERENCES major(id)#为studinfo的majorid添加major表的id作为外键
)

主键和唯一的对比

保证唯一性保证唯一性一个表中可否有多个是否允许组合
主键约束X最多1个√ ,但不推荐
唯一约束可以有多个√ ,但不推荐

外键的特点

  • 要求在从表设置外键关系
  • 从表的外键列的类型和主表的列的类型是一致的(名称不要求一致)
  • 主表的关联列必须是一个key(一般是主键或者唯一)
  • 插入数据时,先插入主表,再插入从表
  • 删除数据时,先删除从表数据,在删除主表数据
7、修改表时添加约束

1、添加非空约束

ALTER TABLE stuinfo MODIFY COLUMN  stuname VARCHAR(20) NOT NULL

2、添加默认约束

ALTER TABLE stuinfo MODIFY COLUMN  age INT DEFAULT 19

3、添加主键约束

ALTER TABLE stuinfo MODIFY COLUMN id INT  PRIMARY KEY

4、添加唯一约束

ALTER TABLE stuinfo MODIFY COLUMN seat  INT  UNIQUE

5、添加外键约束

ALTER TABLE stuinfo ADD CONSTRAIN FOREIGN KEY (majorid) REFERENCES major(id)

总结:
1、添加列级约束
alter table 表名 modify column 字段名 字段类型 新约束
2、添加表级约束
alter table 表名 add 【contraint 约束名】 约束类型(字段名)【外键应用】

8、修改表时添加约束

1、删除非空约束
2、删除默认约束
以上实际就是重新设置约束
3、删除主键约束

alter table stuinfo drop primary key

4、删除唯一约束

alter table stuinfo drop index seat

5、删除外键约束

alter table stuinfo drop foregin key fk_stuinfo_major
9、标识列

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

特点:

  • 标识列不一定非要和主键搭配,看必须是一个key
  • 一个表可以有最多1个标识列
  • 标识列的类型必须是数值型,int double之类,但多为int
  • 标识列可以通过set auto_increatment_increment=3设置步长
  • 可以通过手动插入值设置起始标识数。

1、创建表时设置标识列

CREATE TABLE tab_identity(
id INT PRIMARY KEY AUTO_INCREMENT,
NAME VARCHAR(20)
)

2、修改表时设置标识列

ALTER TABLE tab_identity MODIFY COLUMN id INT PRIMARY KEY AUTO_INCREMENT

2、修改表时删除标识列

ALTER TABLE tab_identity MODIFY COLUMN id INT//直接去除就可以

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值