1.创建表
创建表操作的sql语句可以分为以下几个部分
CREATE TABLE 表名(字段名 数据类型 [约束条件] ,字段名 数据类型 [约束条件] ,字段名 数据类型 [约束条件]);
- mysql常用数据类型有
数值类型:TINYINT, SMALLINT, MEDIUMINT, INT/INTEGER, BIGINT, FLOAT, DOUBLE, DECIMAL(M,N)取值范围在M和N之 间
字符类型(有BLOB的都是二进制形式文本数据):CHAR, VARCHAR, TINYBLOB, BLOB, TEXT, MEDIUMBLOB, MEDIUMTEXT, LONGBLOB, LONGTEXT
日期和时间类型:DATE(YYYY-MM-DD), TIME(HH-mm-ss), DATETIME(YYYY-MM-DD HH-mm-ss), YEAR(YYYY), DATESTAMP(YYYYMMDDHHmmss)
- 常用约束条件有
PRIMARY KEY(主键):
CREATE TABLE student(
id INT,
name VARCHAR(20),
PRIMARY KEY(id)
);
CREATE TABLE student(
id INT,
name VARCHAR(20),
PRIMARY KEY(id,name)
);
(PRIMARY可以省略不写)可以设置复合主键,主键必须唯一
NOT NULL(非空):
CREATE TABLE IF NOT EXISTS student(
id INT,
name VARCHAR(20) NOT NULL,
PRIMARY KEY(id)
)
字段设置非空约束,就必须给值,给NULL字符串也可以成功插入,但必须给值
AUTO_INCREMENT(自增长)
CREATE TABLE IF NOT EXISTS student(
id INT PRIMARY KEY AUTO_ICREMENT,
name VARCHAR(20) NOT NULL
)AUTO_INCRMENT=100
自增长初始值默认从1开始,可以通过AUTO_INCREMENT=n设置初始值为n
DEFAULT(默认值)
CREATE TABLE IF NOT EXISTS student(
id INT PRIMARY KEY AUTO_INCREMENT,
name VARCHAR(20) NOT NULL,
sex CHAR(2) DEFAULT '男'
)AUTO_INCREMENT=100
如果被设置有默认值的字段没有赋值,则会自动给默认值
UNIQUE KEY(唯一约束,唯一字段可以设置多个)
CREATE TABLE IF NOT EXISTS student(
id INT PRIMARY KEY AUTO_INCREMARY,
name VARCHAR(20) NOT NULL,
sex CHAR(2) DEFAULT '男',
stu_id INT UNIQUE
)AUTO_INCREMENT=100
设置唯一约束的字段,值不可以重复
- 创建表的其他参数
CHARSET(设置字符编码):默认UTF-8
ENGINE(存储引擎):默认INNODB
CREATE TABLE IF NOT EXISTS student(
id INT PRIMARY KEY AUTO_INCREMARY,
name VARCHAR(20) NOT NULL,
sex CHAR(2) DEFAULT '男',
stu_id INT UNIQUE
)ENGINE=INNODB,CHARSET=UTF-8,AUTO_INCREMENT=100
2.删除表
DROP TABLE 表名;
3.修改表
ALTER TABLE 表名 ADD|DROP|MODIFY|CHANGE|ALTER|RENAME
- ADD(新增字段)
ALTER TABLE student ADD class_id INT;//接最后一列添加新字段class_id
ALTER TABLE student ADD class_id INT FIRST;//在第一列添加新字段class_id
ALERT TABLE student ADD class_id INT AFTER sex;//在sex字段之后添加新字段class_id
- DROP(删除字段)
ALTER TABLE student DROP class_id;//删除class_id字段
- MODIFY和CHANGE(修改字段)
MODIFY和CHANGE都可以修改字段,其区别就在于:
CHANGE必须指定新的字段名而MODIFY则不需要(如果需要修改字段名只能用CHANGE,否则用哪个都可以)
ALTER TABLE student CHANGE class_id c_id VARCHAR(20);//将class_id字段名改为c_id并修改数据类型为VARCHAR(20)
ALTER TABLE student CHANGE class_id class_id VARCHAR(20);//修改class_id数据类型为VARCHAR(20)不修改字段名
ALTER TABLE student MODIFY class_id VARCHAR(20);//将class_id数据类型修改为VARCHAR(20)
- ALTER(设置默认值)
ALTER TABLE student ALTER class_id SET DEFAULT 0;//设置默认值为0
ALTER TABLE student ALTER class_id DROP DEFAULT;//删除默认值
*为什么有了MODIFY和CHANGE还要来个ALTER呢?这是因为另外两个在修改的时候会把字段之前旧的属性全部覆盖掉
举个栗子:现在需要修改class_id DEFAULT的值,我们需要这么写
ALTER TABLE student MODIFY class_id VARCHAR(20) DEFAULT 10;
而采用ALTER则不需要则可以只需要设置默认值
- RENAME(重命名数据表)
ALTER TABLE student RENAME TO student_test;//将student表名改为student_test
- 还可以修改存储引擎
ALTER TABLE student ENGINE=myisam;//将存储引擎修改为myisam