日期类型
SQL
全称 Structured Query Language,结构化查询语言。操作关系型数据库的编程语言,定义了 一套操作关系型数据库统一标准
SQL通用语法
在学习具体的SQL语句之前,先来了解一下SQL语言的同于语法。
1). SQL语句可以单行或多行书写,以分号结尾。
2). SQL语句可以使用空格/缩进来增强语句的可读性。
3). MySQL数据库的SQL语句不区分大小写,关键字建议使用大写
4). 注释:单行注释:-- 注释内容 或 # 注释内容 多行注释:/* 注 释内容 */
SQL分类
DDL
查询所有数据库
SHOW DATABASES;
查看当前数据库
SELECT DATABASE();
创建数据库 方括号内是可选参数
标准语法 create database [ if not exists ] 数据库名 [ default charset 字符集 ] [ collate 排序规则 ] ;
create database itcast;
删除数据库 drop database [ if exists ] 数据库名 ; if exists 代表数据库存在在删除
DROP DATABASE IF EXISTS teste;
切换数据库 use 数据库名
use test
对表定义操作
查询当前数据库所有表
show tables;
查询表结构 desc 表名
desc test;
查看创建表语句 SHOW CREATE TABLE 表名
SHOW CREATE TABLE tb_blog;
创建表
/*
CREATE TABLE 表名(
字段1 字段1类型 [ COMMENT 字段1注释 ],
字段2 字段2类型 [COMMENT 字段2注释 ],
字段3 字段3类型 [COMMENT 字段3注释 ],
…
字段n 字段n类型 [COMMENT 字段n注释 ]
) [ COMMENT 表注释 ] ;
*/
创建tb_blog表
CREATE TABLE tb_blog
(
id
bigint unsigned NOT NULL AUTO_INCREMENT COMMENT ‘主键’,
shop_id
bigint NOT NULL COMMENT ‘商户id’,
user_id
bigint unsigned NOT NULL COMMENT ‘用户id’,
title
varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NOT NULL COMMENT ‘标题’,
images
varchar(2048) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL COMMENT ‘探店的照片,最多9张,多张以","隔开’,
content
varchar(2048) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NOT NULL COMMENT ‘探店的文字描述’,
liked
int unsigned DEFAULT ‘0’ COMMENT ‘点赞数量’,
comments
int unsigned DEFAULT NULL COMMENT ‘评论数量’,
create_time
timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT ‘创建时间’,
update_time
timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT ‘更新时间’,
PRIMARY KEY (id
) USING BTREE
) ENGINE=InnoDB AUTO_INCREMENT=24 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci ROW_FORMAT=COMPACT
修改字段 ALTER TABLE 表名 ADD 字段名 类型 (长度) [ COMMENT 注释 ] [ 约束 ];
ALTER TABLE emp ADD nickname varchar(20) COMMENT ‘昵称’;
修改数据库类型
ALTER TABLE emp MODIMY 字段名 新数据类型 (长度)
修改数据类型和字段名称
ALTER TABLE 表名 CHANGE 旧字段名 新字段名 新类型 (长度) [ COMMENT 注释 ] [ 约束 ];
删除字段
ALTER TABLE 表名 drop 字段名称
# 修改表名
ALTER TABLE 表名 RENAME TO 新表名
# 删除表
DROP TABLE 表名 或 TRUNCATE TABLE 表名;
# TRUNCATE 删除后创建新表
DML
数据操作语言,对数据库表中数据进行增删改操作。
1)添加数据【INSERT】
2)修改数据【UPDATE】
3)删除数据【DELETE】
添加数据
修改数据
删除数据
DQL
数据查询语言,用来查询数据库表中记录。关键字SELECT
图片
PART01
语法
语法
/*
SELECT
字段列表
FROM
表名列表
WHERE
条件列表
GROUP BY
分组字段列表
HAVING
分组后条件列表
ORDER BY
排序字段列表
LIMIT
分页参数
*/
基础查询
查询多个字段语法 SELECT 字段1, 字段2, 字段3 … FROM 表名 ;
查询所有字段语法 SELECT * FROM 表名 ;
例
SELECT name,age FROM emp;
SELECT * FROM emp;
* 代表查询所有字段,影响效率,开发中不推荐使用
设置别名语法 SELECT 字段1 [ AS 别名1 ] , 字段2 [ AS 别名2 ] … FROM 表名;
简写形式 SELECT 字段1 [ 别名1 ] , 字段2 [ 别名2 ] … FROM 表名;
例
SELECT name AS ename,workno no,age FROM emp;
去除重复记录语法 SELECT DISTINCT 字段列表 FROM 表名;
例
select distinct workaddress ‘工作地址’,dep_id from emp;
注:distinct是对当前记录去重,当distinct后面跟多个字段时,去重条件为这几个字段的值
条件拆查询
语法
SELECT 字段列表 FROM 表名 WHERE 条件列表 ;
案例
查询年龄等于 88 的员工
select * from emp where age = 88;
查询年龄小于 20 的员工信息
select * from emp where age < 20;
查询年龄小于等于 20 的员工信息
select * from emp where age <= 20;
查询没有身份证号的员工信息
select * from emp where idcard is null;
查询有身份证号的员工信息
select * from emp where idcard is not null;
查询年龄不等于 88 的员工信息
select * from emp where age != 88;
查询年龄在15岁(包含) 到 20岁(包含)之间的员工信息
select * from emp where age >= 15 && age <= 20;
查询性别为 女 且年龄小于 25岁的员工信息
select * from emp where gender = ‘女’ and age < 25;
查询年龄等于18 或 20 或 40 的员工信息
select * from emp where age = 18 or age = 20 or age =40;
select * from emp where age in(18,20,40);
查询姓名为两个字的员工信息 _ %
select * from emp where name like ‘__’;
查询身份证号最后一位是X的员工信息
select * from emp where idcard like ‘%X’;
select * from emp where idcard like ‘_________________X’;
聚合函数
语法
SELECT 聚合函数(字段列表) FROM 表名 ;
常见聚合函数
案例
统计该企业员工数量
select count() from emp; – 统计的是总记录数
select count(idcard) from emp; – 统计的是idcard字段不为null的记录数
#对于count聚合函数,统计符合条件的总记录数,还可以通过 count(数字/字符串)的形式进行统计查询,比如:
select count(1) from emp;
/ 对于count() 、count(字段)、 count(1) 的具体原理,我们在进阶篇中SQL优化部分会详
细讲解,此处大家只需要知道如何使用即可/。
#统计该企业员工的平均年龄
select avg(age) from emp;
统计该企业员工的最大年龄
select max(age) from emp;
统计该企业员工的最小年龄
select MIN(age) from emp;
统计西安地区员工的年龄之和
select sum(age) from emp where workaddress = ‘西安’;
分组查询
语法
SELECT 字段列表 FROM 表名 [ WHERE 条件 ] GROUP BY 分组字段名 [ HAVING 分组
后过滤条件 ];
where与Having的区别
案例
根据性别分组 , 统计男性员工 和 女性员工的数量
select gender, count(*) from emp group by gender ;
根据性别分组 , 统计男性员工 和 女性员工的平均年龄
select gender, avg(age) from emp group by gender ;
查询年龄小于45的员工 , 并根据工作地址分组 , 获取员工数量大于等于3的工作地址
select workaddress, count(*) address_count from emp where age < 45 group by
workaddress having address_count >= 3;
统计各个工作地址上班的男性及女性员工的数量
select workaddress, gender, count(*) ‘数量’ from emp group by workaddress,gender
排序查询
语法
SELECT 字段列表 FROM 表名 ORDER BY 字段1 排序方式1 , 字段2 排序
案例
根据年龄对公司的员工进行升序排序
select * from emp order by age asc;
select * from emp order by age;
根据入职时间, 对员工进行降序排序
select * from emp order by entrydate desc;
根据年龄对公司的员工进行升序排序 , 年龄相同 , 再按照入职时间进行降序排序
select * from emp order by age asc , entrydate desc;
分页查询
语法
SELECT 字段列表 FROM 表名 LIMIT 起始索引, 查询记录数 ;
案例
查询第1页员工数据, 每页展示10条记录
select * from emp limit 0,10;
select * from emp limit 10;
查询第2页员工数据, 每页展示10条记录 --------> (页码-1)*页展示记录数
select * from emp limit 10,10;
DCL
数据控制语言,用来管理数据库用户,控制数据库的访问权限。
管理用户
查询用户
select * from mysql.user;
图片
创建用户
CREATE USER ‘用户名’@‘主机名’ IDENTIFIED BY ‘密码’
修改用户密码
ALTER USER ‘用户名’@‘主机名’ IDENTIFIED WITH mysql_native_password BY ‘新密码’ ;
删除用户
DROP USER ‘用户名’@‘主机名’ ;
案例
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数Go语言工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Go语言全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Golang知识点,真正体系化!
由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新
如果你觉得这些内容对你有帮助,可以添加V获取:vip1024b (备注Go)
一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
链图片转存中…(img-68z2VWxQ-1712978576645)]
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Golang知识点,真正体系化!
由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新
如果你觉得这些内容对你有帮助,可以添加V获取:vip1024b (备注Go)
[外链图片转存中…(img-sre9cDmb-1712978576646)]
一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!