MySql基础之DDL-数据定义语言(修改表结构)

有时候,不是因为你没有能力,也不是因为你缺少勇气,只是因为你付出的努力还太少,所以,成功便不会走向你。而你所需要做的,就是坚定你的梦想,你的目标,你的未来,然后以不达目的誓不罢休的那股劲,去付出你的努力,成功就会慢慢向你靠近。

导读:本篇文章讲解 MySql基础之DDL-数据定义语言(修改表结构),希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com,来源:原文

1、创建和管理数据库

创建数据库

  • 方式1:创建数据库
CREATE DATABASE 数据库名;
  • 方式2:创建数据库并指定字符集
CREATE DATABASE 数据库名 CHARACTER SET 字符集;
  • 方式3:判断数据库是否已经存在,不存在则创建数据库( 推荐
CREATE DATABASE IF NOT EXISTS 数据库名;

注意:DATABASE 不能改名。一些可视化工具可以改名,它是建新库,把所有表复制到新库,再删
旧库完成的。

使用数据库

  • 查看当前所有的数据库
SHOW DATABASES;
  • 查看当前正在使用的数据库
SELECT DATABASE();
  • 查看指定库下所有的表
SHOW TABLES FROM 数据库名;
  • 查看数据库的创建信息
SHOW CREATE DATABASE 数据库名; 
或者: 
SHOW CREATE DATABASE 数据库名\G
  • 使用/切换数据库
USE 数据库名;

修改数据库

  • 更改数据库字符集
ALTER DATABASE 数据库名 CHARACTER SET 字符集; #比如:gbk、utf8等

删除数据库

  • 方式1:删除指定的数据库
DROP DATABASE 数据库名;
  • 方式2:删除指定的数据库( 推荐 )
DROP DATABASE IF EXISTS 数据库名;

2、创建表

创建方式1

CREATE TABLE [IF NOT EXISTS] 表名( 
	字段1, 数据类型 [约束条件] [默认值], 
	字段2, 数据类型 [约束条件] [默认值], 
	字段3, 数据类型 [约束条件] [默认值], 
	……
	[表约束条件] 
);
-- 创建表 
CREATE TABLE emp (
	-- int类型 
	emp_id INT,
	-- 最多保存20个中英文字符 
	emp_name VARCHAR(20),
	-- 总位数不超过15位 
	salary DOUBLE,
	-- 日期类型 
	birthday DATE 
);

创建方式2

使用 AS subquery 选项,将创建表和插入数据结合起来

-- 创建的emp1和employees表结构相同数据相同
CREATE TABLE emp1 AS SELECT * FROM employees; 

-- 创建的emp2是空表
CREATE TABLE emp2 AS SELECT * FROM employees WHERE 1=2; 

查看数据表结构

show create table emp1

在这里插入图片描述

3、修改表

追加一个列

语法格式如下:

ALTER TABLE 表名 
ADDCOLUMN】 字段名1 字段类型 【FIRST|AFTER 字段名2;

举例:

ALTER TABLE dept80 
ADD job_id varchar(15);

注意:默认添加字段在最后,可以通过first或after字段名调整位置

修改一个列

可以修改列的数据类型,长度、默认值和位置
修改字段数据类型、长度、默认值、位置的语法格式如下:

ALTER TABLE 表名 
MODIFYCOLUMN】 字段名1 字段类型 
【DEFAULT 默认值】【FIRST|AFTER 字段名2;

重命名一个列

语法格式如下:

ALTER TABLE 表名 
CHANGE 【column】 列名 新列名 新数据类型;

举例:

ALTER TABLE dept80 
CHANGE department_name dept_name varchar(15);

删除一个列

格式如下:

ALTER TABLE 表名 DROPCOLUMN】字段名

举例:

ALTER TABLE dept80 
DROP COLUMN job_id;

重命名表

  • 方式一:使用RENAME
RENAME TABLE emp TO myemp;
  • 方式二:
ALTER table dept 
RENAME [TO] detail_dept; -- [TO]可以省略

4、删除表

语法格式:

DROP TABLE [IF EXISTS] 数据表1 [, 数据表2,, 数据表n];
  • DROP TABLE 语句不能回滚

清空表

删除表中所有的数据

TRUNCATE TABLE detail_dept;

TRUNCATE语句不能回滚,而使用 DELETE 语句删除数据,可以回滚

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/148625.html

(0)
飞熊的头像飞熊bm

相关推荐

发表回复

登录后才能评论
极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!