MySql基础——表操作

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

你可能感兴趣的:(------MySql,数据存储)