MySQL_创建和管理表

创建和管理表分以下几个步骤进行学习:

• 创建数据库

• 创建表

• 描述各种数据类型

• 修改表

• 删除,清空表和重命名

(1)创建数据库

● 创建一个保存老师信息的数据库
打开Navicat中的MySQL,并右键打开命令行界面,输入以下的sql语句。从下面的图已经显示创建成功,最后右键刷新数据库,能显示出teacher。

CREATE database teacher;

MySQL_创建和管理表
MySQL_创建和管理表
● 相关其他命令
查看当前所有数据库,下图显示有九个记录。

show databases;

MySQL_创建和管理表

“使用”一个数据库,使其作为当前数据库,这个一般要结合相应的DML语句一起使用。

use `teacher`;
命名规则
数据库名不得超过30个字符,变量名限制为29个
必须只能包含 A–Z, a–z, 0–9, _共63个字符
不能在对象名的字符间留空格
必须不能和用户定义的其他对象重名
必须保证你的字段没有和保留字、数据库系统或常用方法冲突
保持字段名和类型的一致性,在命名字段并为其指定数据类型的时候一定要保证一致性。假如数据类型在一个表里是整数,那在另一个表里可就别变成字符型了

(2)创建表

CREATE TABLE 语句

• 必须具备:
– CREATE TABLE权限
– 存储空间

• 必须指定:
– 表名
– 列名, 数据类型, 尺寸

• 语法

CREATE TABLE demo
			(id INT(2),
			name VARCHAR(14));

MySQL_创建和管理表

• 确认

DESCRIBE demo;

MySQL_创建和管理表
新建表:

CREATE TABLE emp (
#int类型,自增
emp_id INT AUTO_INCREMENT,
#最多保存20个中英文字符
emp_name CHAR (20),
#总位数不超过15位
salary DOUBLE,
#日期类型
birthday DATE,
#主键
PRIMARY KEY (emp_id)
) ;

MySQL_创建和管理表
MySQL_创建和管理表

(3)描述各种数据类型

常用数据类型
类型 说明
INT 使用4个字节保存整数数据
CHAR(size) 定长字符数据。若未指定,默认为1个字符,最大长度255
VARCHAR(size) 可变长字符数据,根据字符串实际长度保存, 必须指定长度
FLOAT(M,D) 单精度, M=整数位+小数位, D=小数位。 D<=M<=255,0<=D<=30,默认M+D<=6
DOUBLE(M,D) 双精度。 D<=M<=255,0<=D<=30,默认M+D<=15
DATE 日期型数据,格式’YYYY-MM-DD’
BLOB 二进制形式的长文本数据,最大可达4G
TEXT 长文本数据,最大可达4G

(4)修改表

ALTER TABLE 语句

使用 ALTER TABLE 语句可以实现:
● 向已有的表中添加列
● 修改现有表中的列
● 删除现有表中的列
● 重命名现有表中的列

追加一个新列

ALTER TABLE emp
ADD job_id VARCHAR(15);

MySQL_创建和管理表

MySQL_创建和管理表

修改一个列

• 可以修改列的数据类型, 尺寸和默认值

ALTER TABLE emp
MODIFY (job_id VARCHAR(30));

• 对默认值的修改只影响今后对表的修改

ALTER TABLE emp
MODIFY (salary double(9,2) default 1000);

删除一个列

使用 DROP COLUMN 子句删除不再需要的列

ALTER TABLE emp
DROP COLUMN birthday;

MySQL_创建和管理表
MySQL_创建和管理表

重命名一个列

使用 CHANGE old_column new_column dataType子句重命名列

ALTER TABLE emp
CHANGE emp_id id int(10);

MySQL_创建和管理表
MySQL_创建和管理表
MySQL_创建和管理表

(5)删除,清空表和重命名

删除表

• 数据和结构都被删除
• 所有正在运行的相关事务被提交
• 所有相关索引被删除
• DROP TABLE 语句不能回滚

DROP TABLE demo;

MySQL_创建和管理表

清空表

• TRUNCATE TABLE 语句:
– 删除表中所有的数据
– 释放表的存储空间

TRUNCATE TABLE demo1;

MySQL_创建和管理表

• TRUNCATE语句不能回滚
• 可以使用 DELETE 语句删除数据,可以回滚
• 对比:

DELETE FROM emp;
SELECT * FROM emp;
ROLLBACK;
SELECT * FROM emp;

重命名

• 执行RENAME语句改变表, 视图的名称
• 必须是对象的拥有者

ALTER table emp
RENAME TO seven;

MySQL_创建和管理表
MySQL_创建和管理表

上一篇:MySQL数据库索引


下一篇:oracle怎样恢复自己已经删除提交的数据