MySQL教程笔记

news2025/1/10 21:22:57

MySQL

关系型数据库:建立在关系模型基础上,由多张相互连接的二维表组成的数据库。

MYSQL基础

DDL

Data Definition Language,数据定义语言,用来定义数据库对象(数据库,表,字段) 。
相关操作如下:

数据库相关
# 查询所有数据库
show databases;

#选择数据库
use template;

#  查询当前数据库
select database();

# 创建数据库
create database if not exists cxk;
create database if not exists cxk2 default charset utf8mb4;


# 删除数据库
drop database if exists cxk2;
表相关
# 查询当前数据库所有表
show tables;

# 查看表结构
desc user;

# 查看建表语句
show create table user;

# 创建表结构
create table tb_user
(
    id int comment '编号',
    name varchar(50) comment '姓名',
    age int comment '年龄',
    gender varchar(1) comment '性别'
) comment '用户表'

数据类型
数值类型
类型大小范围(有符号)范围(无符号)用途
TINYINT1 Bytes(-128,127)(0,255)小整数值
SMALLINT2 Bytes(-32 768,32 767)(0,65 535)大整数值
MEDIUMINT3 Bytes(-8 388 608,8 388 607)(0,16 777 215)大整数值
INT或INTEGER4 Bytes(-2 147 483 648,2 147 483 647)(0,4 294 967 295)大整数值
BIGINT8 Bytes(-9,223,372,036,854,775,808,9 223 372 036 854 775 807)(0,18 446 744 073 709 551 615)极大整数值
FLOAT4 Bytes(-3.402 823 466 E+38,-1.175 494 351 E-38),0,(1.175 494 351 E-38,3.402 823 466 351 E+38)0,(1.175 494 351 E-38,3.402 823 466 E+38)单精度
浮点数值
DOUBLE8 Bytes(-1.797 693 134 862 315 7 E+308,-2.225 073 858 507 201 4 E-308),0,(2.225 073 858 507 201 4 E-308,1.797 693 134 862 315 7 E+308)0,(2.225 073 858 507 201 4 E-308,1.797 693 134 862 315 7 E+308)双精度
浮点数值
DECIMAL对DECIMAL(M,D) ,如果M>D,为M+2否则为D+2依赖于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极大文本数据
日期和时间类型
类型大小
( bytes)
范围格式用途
DATE31000-01-01/9999-12-31YYYY-MM-DD日期值
TIME3‘-838:59:59’/‘838:59:59’HH:MM:SS时间值或持续时间
YEAR11901/2155YYYY年份值
DATETIME8‘1000-01-01 00:00:00’ 到 ‘9999-12-31 23:59:59’YYYY-MM-DD hh:mm:ss混合日期和时间值
TIMESTAMP4‘1970-01-01 00:00:01’ UTC 到 ‘2038-01-19 03:14:07’ UTC

结束时间是第 2147483647 秒,北京时间 2038-1-19 11:14:07,格林尼治时间 2038年1月19日 凌晨 03:14:07
YYYY-MM-DD hh:mm:ss混合日期和时间值,时间戳
  • CHAR(字符):CHAR 类型用于存储定长字符串。这意味着无论实际字符串长度是多少,CHAR 列始终占据固定数量的字符位置。如果存储的字符串不足指定长度,MySQL 会使用空格进行填充。这会导致 CHAR 类型占用的存储空间通常较大,但检索数据速度较快。
  • VARCHAR(可变字符):VARCHAR 类型用于存储可变长度字符串。它只占据实际数据的存储空间,不会浪费额外的空间用于填充。因此,VARCHAR 类型在存储时通常更有效,但在检索数据时可能略慢一些。
表操作案例
# 表操作案例
create table emp
(
    id int comment '编号',
    workno varchar(10) comment '员工编号',
    name varchar(10) comment '姓名',
    gender char(1) comment '性别',
    age tinyint comment '年龄',
    idcard char(18) comment '身份证',
    entrydate date comment '入职时间'
) comment '员工表'
字段修改
# 添加字段
alter table emp
    add nickname varchar(20) comment '昵称';

# 修改数据类型
alter table emp
    modify nickname varchar(30);

# 修改字段和字段类型
alter table emp
    change nickname username varchar(30) comment '昵称';

# 删除字段
alter table emp
    drop username;

# 修改表名
 alter table emp rename to employee;

# 删除表
drop table if exists tb_user;

DML

DML英文全称是Data Manipulation Language(数据操作语言),用来对数据库中表的数据记录进
行增、删、改操作。

# 添加数据
insert into tb_user(id, name, age, gender)
values (1, '蔡徐坤', 18, '女');

# 给全部字段添加数据
insert into tb_user
values (2, '蔡徐坤', 18, '女');

# 批量添加数据
insert into tb_user (id, name, age, gender)
values (3, '蔡徐坤', 18, '女'),
       (4, '蔡徐坤', 18, '女');


# 查询数据

select * from tb_user;

# 修改数据
update tb_user set name='蔡徐坤爸爸' where id = 4;

update tb_user set name='蔡徐坤奶奶',   age=100 where id = 3;

update tb_user set gender='男';


# 删除数据
delete from tb_user where id = 2;

# 删除所有
delete from tb_user;

DQL

DQL英文全称是Data Query Language(数据查询语言),数据查询语言,用来查询数据库中表的记
录。

SELECT
	字段列表
FROM
	表名列表
WHERE
	条件列表
GROUP BY
	分组字段列表
HAVING
	分组后条件列表
ORDER BY
	排序字段列表
LIMIT
	分页参数
基础查询
# 查询多个字段
select id,name from emp;
select * from emp;

# 字段设置别名
select id,name as 姓名 from emp;
select id as 序号,name as 姓名 from emp;

# 去重
select distinct workaddress as  '工作地址' from emp;
条件查询

# 条件查询 =
select  * from  emp where age=18;
# 查询年龄<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 and age<=20;
select  * from emp where age>=15 && age<=20;
select  * from emp where age between 15 and 20;
# 查询性别为女,年龄<25的员工
select  * from emp where age<25 and gender='女';
# 查询年龄为18 ,20 ,40岁的人
select * from emp where age=18 or age=20 or age=40;
# 查询姓名为两个字的员工
select * from  emp where name like '__';
# 查询身份证最后一个是x的人
select * from  emp where idcard like '%X';
select * from  emp where idcard like '_________________X';

聚合函数
# 统计总的记录数
select count(*)  from emp;
# 统计的是idcard字段不为null的记录数
select  count(idcard) from emp;
select  count(1) from emp;
# 统计平均年龄
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的区别:

  • where 是在分组之前进行过滤,不能进行聚合函数判断
  • 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(*) cnt from emp
where age<45 group by workaddress having  cnt>=3;

# 统计各个工作地址上班的男性及女性员工的数量
select  workaddress,gender,count(*)  '数量' from emp
group by gender, workaddress;
排序查询

格式:

SELECT 字段列表 FROM 表名 ORDER BY 字段1 排序方式1 , 字段2 排序方式2 ;

ASC:升序
DESC:降序

如果是多字段排序,当第一个字段值相同时,才会根据第二个字段进行排序

# 根据年龄升序排序
select * from  emp order by  age asc ;
# 根据入职时间,降序排序
select  * from  emp order by entrydate desc ;
# 根据年龄升序,入职时间降序排序
select * from  emp order by age asc,entrydate desc;
分页查询

格式:

SELECT 字段列表 FROM 表名 LIMIT 起始索引, 查询记录数 

起始索引从0开始,起始索引 = (查询页码 - 1)* 每页显示记录数。

如果查询的是第一页数据,起始索引可以省略,直接简写为 limit 10。

# 查询第一页,每页10条
select * from  emp limit 0,10;
select * from  emp limit 10;
#查询第二页,每页10条 公式:(页码-1)*每页条数
select * from emp limit 10,10;
练习
# 查询年龄为20,21,22,23岁的女员工信息。
select * from  emp where gender='女' and age in (20,21,22,23);
# 查询性别为 男 ,并且年龄在 20-40 岁(含)以内的姓名为三个字的员工。
select  * from emp where gender='男' and (age between 20 and 40) and name like '___';
# 统计员工表中, 年龄小于60岁的 , 男性员工和女性员工的人数。
select  gender,count(*) from emp where age<60 group by gender;
# 查询所有年龄小于等于35岁员工的姓名和年龄,并对查询结果按年龄升序排序,如果年龄相同按入职时间降序排序。
select name,age from emp where age<=35 order by age asc,entrydate desc;
# 查询性别为男,且年龄在20-40 岁(含)以内的前5个员工信息,对查询的结果按年龄升序排序,年龄相同按入职时间升序排序
select * from emp where gender='男' and age between 20 and 40 order by age asc,entrydate asc limit 5;

执行顺序
image.png

DCL

DCL英文全称是Data Control Language(数据控制语言),用来管理数据库用户、控制数据库的访 问权限。

用户管理
# 查询用户
select * from  mysql.user;
# 创建用户
create user 'test'@'localhost' identified by '12345678';
# 修改用户密码
alter user 'test'@'localhost'  identified with  mysql_native_password by '123456789';
# 删除用户
drop user 'test'@'localhost';

权限控制
权限说明
all,all privileges所有权限
select查询
insert插入
update修改
delete删除
alter修改表
drop删除数据库/表
create创建数据库 /表

查询权限

  • SHOW GRANTS FOR ‘用户名’@‘主机名’ ;
    授权
  • GRANT 权限列表 ON 数据库名.表名 TO ‘用户名’@‘主机名’;
    撤销权限
  • REVOKE 权限列表 ON 数据库名.表名 FROM ‘用户名’@‘主机名’;
# 查询test用户的权限
show grants  for 'test'@'localhost';
# 授权
grant all on template.* to 'test'@'localhost';
# 撤销权限
revoke all on template.* from 'test'@'localhost';

函数

常用函数
  • concat(s1,s2) ,字符串拼接
  • lower(str),全部转为小写
  • upper(str),转为大写
  • lpad(str,n,pad) ,用字符串pad对str进行作填充,直到长度为n
  • rpad(str,n,pad)
  • trim(str) ,去掉首尾空格
  • substring(str,start,len),返回 str从start开始对len个长度的字符串
# 字符串拼接
select  concat('hello','world');
# 转小写
select lower('HELLO');
# 转大写
select upper('hello');
# 左填充
select lpad('hello',10,'*');
# 右填充
select rpad('hello',10,'*');
# 去空格
select trim(' hello ');
# 截取
select substr('hello',1,2);

# 将emp的所有id变为6为 ,不满的前面补0
update emp set workno = lpad(workno,6,'0');
数值函数
  • ceil 上取整
  • floor 下取整
  • mod(x,y) 返回x/y的模
  • rand(),返回0-1度随机数
  • round(x,y) 求x四舍五入结果
# ceil 上取整
select ceil(1.1);
# floor 下取整
select floor(1.1);
# mod(x,y) 返回x/y的模
select mod(5,2);
# rand(),返回0-1度随机数
select rand();
# round(x,y) 求x四舍五入结果
select round(1.5);
# 生成6为随机验证码
select lpad(round(rand()*1000000),6,'0')
日期函数
  • curdate 当前日期
  • curtime 当前时间
  • now 当前日期和时间
  • year(date) 指定的年份
  • month(date) 月份
  • day(date) 日期
  • date_add(date,interval,exprtype) 返回一个日期间隔 expr后的时间
  • datediff(date1,date2) 间隔天数
# curdate 当前日期
select curdate();
#  curtime 当前时间
select curtime();
#  now 当前日期和时间
select now();
#  year(date) 指定的年份
select year(now());
#  month(date) 月份
select month(now());
#  day(date) 日期
select day(now());
#  date_add(date,interval,exprtype) 返回一个日期间隔 expr后的时间
select date_add(now(), interval 1 day);
#  datediff(date1,date2) 间隔天数
select datediff('2019-01-01', '2019-03-02');

# 查询所有员工的入职天数,并根据入职天数倒序排序。
select name, datediff(curdate(), entrydate) as '入职天数'
from emp
order by entrydate desc
流程函数
  • if(value,t,f) 如果value为true,返回t,否则f
  • ifnull(value1,value2) 如果value1不为空,则返回value1,否则value2
  • case when [val1] then [res1] ... else [default] end如果val1位true,返回res1,否则返回默认
  • case [expr] when [val1] then [res1] ... else [default] end如果expr为val1,返回res1,否则返回默认
# if
select if(false, 'ok', 'true');
# ifnull
select ifnull('ok', 'default');
select ifnull('', 'default');
select ifnull(null, 'default');
# case when then else and
# 查询emp表的员工姓名和工作地址 (北京/上海 ----> 一线城市 , 其他 ----> 二线城市)
select name,
       (case workaddress
            when '北京' then '一线城市'
            when '上海' then '一线城市'
            else
                '二线城市 ' end) as '工作城市'
from emp;

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1152244.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

golang中的Interface接口 类型断言、接口赋值、空接口的使用、接口嵌套

Interface整理 文章目录 Interface整理接口嵌套接口类型断言类型判断 type-switch使用方法集与接口空接口实例 接口赋值给接口 接口是一种契约&#xff0c;实现类型必须满足它&#xff0c;它描述了类型的行为&#xff0c;规定类型可以做什么。接口彻底将类型能做什么&#xff0…

如何在十亿级别用户中检查用户名是否存在?

不知道大家有没有留意过&#xff0c;在使用一些app注册的时候&#xff0c;提示你用户名已经被占用了&#xff0c;需要更换一个&#xff0c;这是如何实现的呢&#xff1f;你可能想这不是很简单吗&#xff0c;去数据库里查一下有没有不就行了吗&#xff0c;那么假如用户数量很多&…

常用排序算法的理解

1.插入排序 插入排序的思想是将一个记录插入到已经排好序的有序表中&#xff0c;从而形成一个新的、记录数加1的有序表。在其实现过程使用双层循环&#xff0c;外层循环是进行插入的次数&#xff08;也可以理解为比较的轮数&#xff09;&#xff0c;内层循环是当前记录查找插入…

Echats-自定义图表2

效果图&#xff1a; 代码&#xff1a; <!DOCTYPE html> <html lang"zh-cmn-Hans"><head><meta charset"UTF-8" /><meta name"viewport" content"widthdevice-width, initial-scale1.0" /><title>…

iptables的四表五链以及一些应用小场景

一、前言 本文主要学习iptables的一些学习&#xff0c;讲解一些四表五链的基本概念&#xff0c;同时通过iptables实现一下场景&#xff0c;比如反向代理端口、禁用域名、限制IP和端口访问。 二、基本概念 2.1 什么是iptables iptables是Linux的防火墙管理工具而已&#xff0c…

昂利康-002940 三季报分析(20231030)

昂利康-002940 基本面分析 基本情况 公司名称&#xff1a;浙江昂利康制药股份有限公司 A股简称&#xff1a;昂利康 成立日期&#xff1a;2001-12-30 上市日期&#xff1a;2018-10-23 所属行业&#xff1a;医药制造业 周期性&#xff1a;0 主营业务&#xff1a;化学原料药及制剂…

hack_me_please靶机攻略

hack_me_please 扫描 探查无果&#xff0c;扫描js的时候有结果 访问可以看到 该页面可以看到是SeedDMS搭的 应该和CMS类似 渗透 漏洞库查找一下有没有该漏洞 使用whatweb扫描一下刚才的页面 whatweb http://10.4.7.154/seeddms51x/seeddms-5.1.22/ 这个版本高于漏洞库的&a…

软考系统架构师知识点集锦八:嵌入式系统

一、考情分析 二、考点精讲 2.1嵌入式系统概述 2.1.1基本概念 (1)嵌入式系统是以应用为中心、以计算机技术为基础,并将可配置与可裁剪的软、硬件集成于一体的专用计算机系统&#xff0c;需要满足应用对功能、可靠性、成本、体积和功耗等方面的严格要求。 (2)从计算机角度看,嵌…

0039Java程序设计-基于java校园闲置物交易系统论文

文章目录 摘 要目 录系统设计开发环境 摘 要 本文的研究方向是设计和实现学生闲置物网上交易平台。目前&#xff0c;各大高校每年都要举办热热闹闹的“跳蚤”市场&#xff0c;就是给师生的一个闲置物品交易的场所&#xff0c;由此可以看出&#xff0c;大学生对闲置物品交易掉的…

数据结构:算法(特性,时间复杂度,空间复杂度)

目录 1.算法的概念2.算法的特性1.有穷性2.确定性3.可行性4.输入5.输出 3.好算法的特质1.正确性2.可读性3.健壮性4.高效率与低存储需求 4.算法的时间复杂度1.事后统计的问题2.复杂度表示的计算1.加法规则2.乘法规则3.常见函数数量级比较 5.算法的空间复杂度1.程序的内存需求2.例…

CAN总线通信协议

Reference video: 趋近于完美的通讯 CAN总线&#xff01;4分钟看懂&#xff01; CAN通信精华整理&#xff0c;汽车工程师必备技能&#xff0c;一个视频带你轻松掌握&#xff01; 写在前面&#xff1a;CAN通信就三个要点 - 波特率的配置 - 过滤寄存器的配置与理解&#xff08;…

Django 社区志愿者管理系统

摘 要 随着社会的发展&#xff0c;社会的各行各业都在利用信息化时代的优势。计算机的优势和普及使得各种信息系统的开发成为必需。 社区志愿者服务管理系统&#xff0c;主要的模块包括查看首页、个人中心、通知公告管理、志愿者管理、普通管理员管理、志愿活动管理、活动宣…

计算机毕业设计选题推荐-超市售货微信小程序/安卓APP-项目实战

✨作者主页&#xff1a;IT研究室✨ 个人简介&#xff1a;曾从事计算机专业培训教学&#xff0c;擅长Java、Python、微信小程序、Golang、安卓Android等项目实战。接项目定制开发、代码讲解、答辩教学、文档编写、降重等。 ☑文末获取源码☑ 精彩专栏推荐⬇⬇⬇ Java项目 Python…

【C语言初学者周冲刺计划】1.1用筛选法求100之内的素数

目录 1解题思路&#xff1a; 2代码如下&#xff1a; 3运行代码如图所示&#xff1a; 4总结&#xff1a; (前言周冲刺计划:周一一个习题实操&#xff0c;依次类推加一&#xff0c;望各位读者可以独自实践敲代码) 1解题思路&#xff1a; 首先了解筛选法定义&#xff1a;先把…

免费的PPT模版--九五小庞

PPT模板&#xff1a; www.1ppt.com/moban/    行业PPT模板&#xff1a;www.1ppt.com/hangye/ 节日PPT模板&#xff1a;www.1ppt.com/jieri/    PPT素材&#xff1a; www.1ppt.com/sucai/PPT背景图片&#xff1a;www.1ppt.com/beijing/   PPT图表&#xff…

AssertionError: Torch not compiled with CUDA enabled

Pytorch和CUDA版本不兼容&#xff0c;运行python后&#xff08;终端输入python回车&#xff09;用以下代码测试 import torch print(torch.__version__) print(torch.cuda.is_available())返回False则说明目前的pytorch版本无法使用显卡&#xff0c;如下图所示 接着重装合适版…

新能源汽车电池包自动三维尺寸检测系统蓝光光学平面度测量仪-CASAIM

电池包是新能源汽车核心能量源&#xff0c;为整车提供驱动电能。作为新能源汽车的核心部件&#xff0c;其品质直接决定了整车性能。 由于电池包的生产工艺相对复杂&#xff0c;传统的测量工具不仅测量工序复杂、精度不足&#xff0c;还会或多或少接触到电池表面形成瑕疵&#…

[UDS] --- ECUReset 0x11

1 0x11功能描述 根据ISO14119-1标准中所述&#xff0c;诊断服务11主要用于Client向Server(ECU)请求重启行为。该重启行为将会导致Server复位回归到特定的初始状态&#xff0c;具体是什么初始状态取决于Client的请求行为。 2 0x11应用场景 一般而言&#xff0c;对于11诊断服务…

案例分析真题-系统建模

案例分析真题-系统建模 2009年真题 【问题1】 【问题2】 【问题3】 2012年真题 【问题1】 【问题2】 【问题3】 2014年真题 【问题1】 【问题2】 骚戴理解&#xff1a;这个题目以前经常考&#xff0c;不知道今年会不会考&#xff0c;判断的话就是看加工有没有缺少输入和输出&a…

Linux进程的概念

一&#xff1a;冯诺依曼体系结构 什么叫做体系结构&#xff1f;&#xff1f;&#xff1f; 计算机组成 / 芯片架构 输入单元&#xff1a;键盘、话筒、摄像头、usb、鼠标、磁盘&#xff08;ROM&#xff09;/ssd、网卡、显卡 存储器&#xff1a;内存&#xff08;RAM&#xff09…