SQL通用语法
1.SQL语句可以单行或多行书写,以分号结尾。
2.SQL语句可以使用空格/缩进来增强语句的可读性。
3.MySQL数据库的SQL语句不区分大小写,关键字建议使用大写。
4.注释:
- 单行注释 :--注释内容或#注释内容(MySQL特有)
- 多行注释 :/*注释内容*/
SQL语句的分类
分类 | 全称 | 说明 |
---|---|---|
DDL | Data Definition Language | 数据定义语言,用来定义数据库对象(数据库,表,字段) |
DML | Data Manipulation Language | 数据操作语言,用来对数据库表中的数据进行增删改 |
DQL | Data Query Language | 数据查询语言,用来查询数据库中表的记录 |
DCL | Data Conntrol Language | 数据控制语言,用来创建数据库用户,控制数据库的访问权限 |
DDL-数据库操作
查询:
查询所有数据库
SHOW DATABASES;
查询当前数据库
SELECT DATABASE();
创建
CREATE DATABASE [IF NOT EXISTS] 数据库名 [DEFAULT CHARSET 字符集] [COLLATE 排序规则];
删除
DROP DATABASE[IF EXISTS]数据库名;
使用
USE 数据库名;
DDL-表操作-查询
查询当前数据库所有表
SHOW TABLEES;
查询表结构
DESC 表名;
查询指定表的建表语句
SHOW CREATEE TABLE 表名;
DDL-表操作-创建
CREATE TABLE 表名(
字段1 字段1类型[COMMENT 字段1注释],
字段2 字段2类型[COMMENT 字段2注释],
字段3 字段3类型[COMMENT 字段3注释],
……
字段n 字段n类型[COMMENT 字段n注释],
)[COMMENT 表注释];
注意:[…]为可选参数,最后一个字段后面没有逗号
DDL-表操作-数据类型
MySQL中的数据类型有很多,主要分为三类:数值类型、字符串类型、日期时间类型。
数据类型
类型 | 大小 | 描述 |
---|---|---|
tinyint | 1 bytes | 小整数值 |
smallint | 2 bytes | 大整数值 |
mediumint | 3 bytes | 大整数值 |
int或integer | 4 bytes | 大整数值 |
bigint | 8 bytes | 极大整数值 |
float | 4 bytes | 单精度浮点数值 |
double | 8 bytes | 双精度浮点数值 |
decimal | 小数值(精确定点数) |
字符串类型
类型 | 大小 | 描述 |
---|---|---|
char | 0~255 bytes | 定长字符串 |
varchar | 0~65535 bytes | 变长字符串 |
tinyblob | 0~255 bytes | 不超过255个字符的二进制数据 |
tinytext | 0~255 bytes | 短文本字符串 |
blob | 0~65535 bytes | 二进制形式的长文本数据 |
text | 0~65535 bytes | 长文本数据 |
mediumblob | 0~16777215 bytes | 二进制形式的中等长度文本数据 |
mediumtext | 0~16777215 bytes | 中等长度文本数据 |
longblob | 0~4294967295 bytes | 二进制形式的极大文本数据 |
longtext | 0~4294967295 bytes | 极大文本数据 |
日期类型
类型 | 大小 | 范围 | 格式 | 描述 |
---|---|---|---|---|
date | 3 | 1000-01-01至9999-12-31 | YYYY-MM-DD | 日期值 |
time | 3 | -838:59:59至838:59:59 | HH:MM:SS | 时间值或持续时间 |
year | 1 | 1901至2155 | YYYY | 年份值 |
datetime | 8 | 1000-01-01 00:00:00至 9999-12-31 23:59:59 | YYYY-MM-DD HH:MM:SS | 混合日期和时间值 |
timestamp | 4 | 1970-01-01 00:00:01至2038-01-19 03:14:07 | YYYY-MM-DD HH:MM:SS | 混合日期和时间值,时间戳 |
案例:根据需求创建表(设计合理的数据类型、长度)
设计一张员工信息表,要求如下:
1.编号(纯数字)
2.员工工号(字符串类型,长度不超过10位)
3.员工姓名(字符串类型,长度不超过10位)
4.性别(男/女,存储一个汉字)
5.年龄(正常人年龄,不可能存储负数)
6.身份证号(二代身份证号均为18位,身份证中有X这样的字符)
7.入职时间(去值年月日即可)
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 '员工表';
DDL-表操作-修改
往表结构中添加字段
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;
删除表
DROP TABLE [IF EXISTS] 表名;
删除指定表,并重新创建该表
TRUNCATE TABLE 表名;
注意:在删除表时,表中的全部数据也会被删除。