网站建设开发,合肥有没有做网站的单位,合肥市城乡建设网站,包装设计作品集SQL之DDL语句 前言DDL数据库操作表操作查询操作数据类型案例修改删除 前言
本篇来学习下SQL中的DDL语句
DDL
全称Data Definition Language#xff0c;数据定义语言#xff0c;用来定义数据库对象(数据库#xff0c;表#xff0c;字段)
数据库操作
查询所有数据库
sh… SQL之DDL语句 前言DDL数据库操作表操作查询操作数据类型案例修改删除 前言
本篇来学习下SQL中的DDL语句
DDL
全称Data Definition Language数据定义语言用来定义数据库对象(数据库表字段)
数据库操作
查询所有数据库
show databases;查询当前数据库
select database();创建数据库
create database [ if not exists ] 数据库名 [ default charset 字符集 ] [ collate 排序
规则 ] ;
# 例 创建xiaobai_db数据库使用默认字符集
create database xiaobai_db;
# if not exists 数据库不存在, 则创建该数据库如果存在则不创建
create database if not exists xiaobai_db1;
# 指定字符集create database xiaobai_db2 default charset utf8mb4;删除数据库
# if exists 如果数据库存在再执行删除否则不执行删除
drop database [ if exists ] 数据库名;
# 删除xiaobai_db数据库
drop database if exists xiaobai_db;切换数据库
use 数据库名;
# 切换到test_db数据库
use test_db;表操作
查询操作
查询当前数据库所有表
show tables;
# 换到sys这个系统数据库,并查看系统数据库中的所有表结构
use sys;
show tables;查看表结构
desc 表名;查询指定表的建表语句
# 主要是用来查看建表语句的而有部分参数我们在创建表的时候并未指定也会查询到因为这部分是数据库的默认值如存储引擎、字符集等
show create table 表名;创建表结构
CREATE TABLE 表名(
字段1 字段1类型 [ COMMENT 字段1注释 ],
字段2 字段2类型 [COMMENT 字段2注释 ],
字段3 字段3类型 [COMMENT 字段3注释 ],
......
字段n 字段n类型 [COMMENT 字段n注释 ]
) [ COMMENT 表注释 ] ;
# 创建tb_user表
create table tb_user(
id int comment 编号,
name varchar(50) comment 姓名,
age int comment 年龄,
gender varchar(1) comment 性别
) comment 用户表;数据类型
MySQL中的数据类型有很多主要分为三类数值类型、字符串类型、日期时间类型。
数值类型
类型大小有符号(SIGNED)范围无符号(UNSIGNED)范围描述TINYINT1byte(-128127)(0255)小整数值SMALLINT2bytes(-3276832767)(065535)大整数值MEDIUMINT3bytes(-83886088388607)(016777215)大整数值INT/INTEGER4bytes(-21474836482147483647)(04294967295)大整数值BIGINT8bytes(-263263-1)(02^64-1)极大整数值FLOAT4bytes(-3.402823466 E383.402823466351 E38)0 和 (1.175494351 E-383.402823466 E38)单精度浮点数值DOUBLE8bytes(-1.7976931348623157E3081.7976931348623157E308)0 和(2.2250738585072014E-3081.7976931348623157E308)双精度浮点数值DECIMAL依赖于M(精度)和D(标度)的值依赖于M(精度)和D(标度)的值小数值(精确定点)
字符串类型
类型大小描述CHAR0-255 bytes定长字符串(需要指定长度)VARCHAR0-65535 bytes变长字符串(需要指定长度)TINYBLOB0-255 bytes不超过255个字符的二进制数据TINYTEXT0-255 bytes短文本字符串BLOB0-65 535 bytes二进制形式的长文本数据TEXT0-65 535 bytes长文本数据MEDIUMBLOB0-16 777 215 bytes二进制形式的中等长度文本数据MEDIUMTEXT0-16 777 215 bytes中等长度文本数据LONGBLOB0-4 294 967 295 bytes二进制形式的极大文本数据LONGTEXT0-4 294 967 295 bytes极大文本数据 char 与 varchar 都可以描述字符串char是定长字符串指定长度多长就占用多少个字符和字段值的长度无关 。而varchar是变长字符串指定的长度为最大占用长度 。相对来说char的性能会更高些。 日期时间类型
类型大小范围格式描述DATE31000-01-01 至 9999-12-31YYYY-MM-DD日期值TIME3 -838:59:59 至 838:59:59HH:MM:SS时间值或持续时间YEAR11901 至 2155YYYY年份值DATETIME81000-01-01 00:00:00 至9999-12-31 23:59:59YYYY-MM-DD HH:MM:SS混合日期和时间值TIMESTAMP41970-01-01 00:00:01 至2038-01-19 03:14:07YYYY-MM-DD HH:MM:SS混合日期和时间值时间戳
案例 设计一张员工信息表要求如下 编号纯数字员工工号 (字符串类型长度不超过10位)员工姓名字符串类型长度不超过10位性别男/女存储一个汉字年龄正常人年龄不可能存储负数身份证号二代身份证号均为18位身份证中有X这样的字符入职时间取值年月日即可 建表语句
create table emp(id int comment 编号,workno varchar(10) comment 工号,name varchar(10) comment 姓名,gender char(1) comment 性别,age tinyint unsigned comment 年龄,idcard char(18) comment 身份证号,entrydate date comment 入职时间
) comment 员工表;修改
添加字段
ALTER TABLE 表名 ADD 字段名 类型 (长度) [ COMMENT 注释 ] [ 约束 ];
# 为emp表增加一个新的字段昵称为nickname类型为varchar(20)
ALTER TABLE emp ADD nickname varchar(20) COMMENT 昵称; 修改数据类型
ALTER TABLE 表名 MODIFY 字段名 新数据类型 (长度); 修改字段名和字段类型
ALTER TABLE 表名 CHANGE 旧字段名 新字段名 类型 (长度) [ COMMENT 注释 ] [ 约束 ];
# 将emp表的nickname字段修改为username类型为varchar(30)
ALTER TABLE emp CHANGE nickname username varchar(30) COMMENT 昵称; 删除字段
ALTER TABLE 表名 DROP 字段名;
# 将emp表的字段username删除
ALTER TABLE emp DROP username;修改表名
ALTER TABLE 表名 RENAME TO 新表名;
# 将emp表的表名修改为 employee
ALTER TABLE emp RENAME TO employee; 删除
删除表
# 可选项 IF EXISTS 代表只有表名存在时才会删除该表表名不存在则不执行删除操作(如果不加该参数项删除一张不存在的表执行将会报错)。
DROP TABLE [ IF EXISTS ] 表名; # 删除tb_uesr表
DROP TABLE IF EXISTS tb_user;删除指定表, 并重新创建表
# 在删除表的时候表中的全部数据也都会被删除。
TRUNCATE TABLE 表名;