视频地址: 黑马程序员 MySQL数据库入门到精通,从mysql安装到mysql高级、mysql优化全囊括
SQL,全称 Structured Query Language,结构化查询语言。操作关系型数据库的编程语言,定义了一套操作关系型数据库统一 标准。
一、SQL通用语法
SQL 语言的通用语法:
(1)SQL语句可以单行或多行书写,以分号结尾。
(2)SQL语句可以使用空格/缩进来增强语句的可读性。
(3)MySQL数据库的SQL语句不区分大小写,关键字建议使用大写。
(4)注释:
1️⃣单行注释:-- 注释内容 或 # 注释内容
2️⃣多行注释:/* 注释内容 */
二、SQL 分类
三、DDL
Data Definition Language,数据定义语言,用来定义数据库对象(数据库,表,字段) 。
1. DDL - 数据库操作
1.1 查询所有数据库
SHOW DATABASES;
1.2 查询当前数据库
SELECT DATABASE();
1.3 创建数据库
CREATE DATABASE [IF NOT EXISTS] 数据库名 [DEFAULT CHARSET 字符集] [COLLATE 排序规则];
1.4 删除数据库
DROP DATABASE [IF EXISTS] 数据库名;
1.5 切换数据库
我们要操作某一个数据库下的表时,就需要通过该指令,切换到对应的数据库下,否则是不能操作的。
USE 数据库名;
2. DDL - 表操作 - 查询创建
2.1 查询当前数据库所有表
show tables;
比如,我们可以切换到 sys 这个系统数据库,并查看系统数据库中的所有表结构。
use sys;
show tables;
2.2 查看指定表结构
desc 表名 ;
通过这条指令,我们可以查看到指定表的字段,字段的类型、是否可以为 NULL,是否存在默认值等信息。
2.3 查询指定表的建表语句
show create table 表名 ;
通过这条指令,主要是用来查看建表语句的,而有部分参数我们在创建表的时候,并未指定也会查询到,因为这部分是数据库的默认值,如:存储引擎、字符集等。
2.4 创建表结构
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 '用户表';
3. DDL - 表操作 - 数据类型
MySQL 中的数据类型有很多,主要分为三类:数值类型、字符串类型、日期时间类型。
3.1 数值类型
如:
1). 年龄字段 -- 不会出现负数, 而且人的年龄不会太大
age tinyint unsigned2). 分数 -- 总分100分, 最多出现一位小数
score double(4,1)
3.2 字符串类型
char 与 varchar 都可以描述字符串,char 是定长字符串,指定长度多长,就占用多少个字符,和字段值的长度无关 。而 varchar 是变长字符串,指定的长度为最大占用长度 。相对来说,char 的性能会更高些。
如:
1). 用户名 username ------> 长度不定, 最长不会超过50
username varchar(50)2). 性别 gender ---------> 存储值, 不是男,就是女
gender char(1)3). 手机号 phone --------> 固定长度为11
phone char(11)
3.3 日期时间类型
如:
1). 生日字段 birthday
birthday date2). 创建时间 createtime
createtime datetime
4. 表操作-案例
设计一张员工信息表,要求如下:
(1)编号(纯数字)
(2)员工工号 (字符串类型,长度不超过10位)
(3)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 '员工表';
5. DDL - 表操作 - 修改
5.1 添加字段
ALTER TABLE 表名 ADD 字段名 类型 (长度) [ COMMENT 注释 ] [ 约束 ];
案例:
为 emp 表增加一个新的字段”昵称”为 nickname,类型为 varchar(20)
ALTER TABLE emp ADD nickname varchar(20) COMMENT '昵称';
5.2 修改数据类型
ALTER TABLE 表名 MODIFY 字段名 新数据类型 (长度);
5.3 修改字段名和字段类型
ALTER TABLE 表名 CHANGE 旧字段名 新字段名 类型 (长度) [ COMMENT 注释 ] [ 约束 ];
案例:
将 emp 表的 nickname 字段修改为 username,类型为 varchar(30)
ALTER TABLE emp CHANGE nickname username varchar(30) COMMENT '昵称';
5.4 删除字段
ALTER TABLE 表名 DROP 字段名;
案例:
将 emp 表的字段 username 删除
ALTER TABLE emp DROP username;
5.5 修改表名
ALTER TABLE 表名 RENAME TO 新表名;
案例:
将 emp 表的表名修改为 employee
ALTER TABLE emp RENAME TO employee;
6. DDL - 表操作 - 删除
6.1 删除表
DROP TABLE [ IF EXISTS ] 表名;
可选项 IF EXISTS 代表,只有表名存在时才会删除该表,表名不存在,则不执行删除操作(如果不加该参数项,删除一张不存在的表,执行将会报错)。
案例:
如果 tb_user 表存在,则删除 tb_user 表
DROP TABLE IF EXISTS tb_user;
6.2 删除指定表, 并重新创建表
TRUNCATE TABLE 表名;
注意: 在删除表的时候,表中的全部数据也都会被删除。
四、DML
DML 英文全称是 Data Manipulation Language(数据操作语言),用来对数据库中表的数据记录进行增、删、改操作。
(1)添加数据(INSERT)
(2)修改数据(UPDATE)
(3)删除数据(DELETE)
1. 添加数据
1.1 给指定字段添加数据
INSERT INTO 表名 (字段名1, 字段名2, ...) VALUES (值1, 值2, ...);
案例:
给 employee 表所有的字段添加数据
insert into employee(id,workno,name,gender,age,idcard,entrydate)
values(1,'1','Itcast','男',10,'123456789012345678','2000-01-01');
1.2 给全部字段添加数据
INSERT INTO 表名 VALUES (值1, 值2, ...);
案例:
插入数据到 employee 表
insert into employee values(2,'2','张无忌','男',18,'123456789012345670','2005-01-01');
1.3 批量添加数据
INSERT INTO 表名 (字段名1, 字段名2, ...) VALUES (值1, 值2, ...), (值1, 值2, ...), (值
1, 值2, ...) ;
INSERT INTO 表名 VALUES (值1, 值2, ...), (值1, 值2, ...), (值1, 值2, ...) ; 1
案例:
插入数据到 employee 表
insert into employee values(2,'2','张无忌','男',18,'123456789012345670','2005-01-01');