创建表操作的sql语句可以分为以下几个部分
CREATE TABLE 表名(字段名 数据类型 [约束条件] ,字段名 数据类型 [约束条件] ,字段名 数据类型 [约束条件]);
数值类型: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)
CREATE TABLE student(
id INT,
name VARCHAR(20),
PRIMARY KEY(id)
);
CREATE TABLE student(
id INT,
name VARCHAR(20),
PRIMARY KEY(id,name)
);
(PRIMARY可以省略不写)可以设置复合主键,主键必须唯一
CREATE TABLE IF NOT EXISTS student(
id INT,
name VARCHAR(20) NOT NULL,
PRIMARY KEY(id)
)
字段设置非空约束,就必须给值,给NULL字符串也可以成功插入,但必须给值
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
CREATE TABLE IF NOT EXISTS student(
id INT PRIMARY KEY AUTO_INCREMENT,
name VARCHAR(20) NOT NULL,
sex CHAR(2) DEFAULT '男'
)AUTO_INCREMENT=100
如果被设置有默认值的字段没有赋值,则会自动给默认值
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
DROP TABLE 表名;
ALTER TABLE 表名 ADD|DROP|MODIFY|CHANGE|ALTER|RENAME
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
ALTER TABLE student DROP class_id;//删除class_id字段
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 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则不需要则可以只需要设置默认值
ALTER TABLE student RENAME TO student_test;//将student表名改为student_test
ALTER TABLE student ENGINE=myisam;//将存储引擎修改为myisam