MySQL基础笔记小结

1. mysql :

1.1启动与停止mysql:

net start mysql80

net stop mysel80

1.2客户端连接:

2种,系统cmd与自带的cmd(直接打开)

mysql -u root-p

1.2.1 数据存储

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

 优点: 使用表来存储数据并且都使用sql语言,格式统一 ,便于维护

不通过表存储数据的是非关系型数据库

1.3 数据模型:

DBMS控制数据库操控数据(表):

客户端连接DBMS,使用sql语句来操控DBMS来创建数据库或在指定的数据库中创建表。

1.4 数据类型

数据类型描述示例存储需求(字节数)
INT(INTEGER)整数类型,有符号范围为 - 2147483648 到 2147483647。123454
BIGINT大整数类型,有符号范围很大。92233720368547758078
SMALLINT小整数类型,有符号范围为 - 32768 到 32767。50002
TINYINT微小整数类型,有符号范围为 - 128 到 127。501
DECIMAL(p,s)定点数类型,p 表示总位数,s 表示小数位数。DECIMAL (5,2) 可存储 123.45根据具体位数定,例如 DECIMAL (5,2) 需要 2 - 3 个字节用于存储小数部分,整数部分最多需要 2 个字节,总共大概需要 5 个字节左右
FLOAT单精度浮点数。3.141594
DOUBLE双精度浮点数。3.1415926535897938
CHAR(n)定长字符串,n 表示字符长度。'Hello'(若定义 CHAR (5) 会补空格)n 个字节,n <= 255,例如 CHAR (10) 占用 10 个字节
VARCHAR(n)变长字符串,n 表示最大字符长度。'World'实际长度加 1 - 2 个字节,n <= 65535

 

TEXT长文本类型。一段较长的描述根据实际长度定,一般来说,短的文本可能占用几个字节到几十个字节,较长的文本可能几百个字节甚至更多
DATE日期类型,格式为 YYYY-MM-DD。'2024-09-07'3
TIME时间类型,格式为 HH:MM:SS。'12:30:45'3
DATETIME日期和时间类型,格式为 YYYY-MM-DD HH:MM:SS。'2024-09-07 12:30:45'8
ENUM枚举类型,只能从给定的值中选择一个。ENUM('red', 'green', 'blue')1 或 2 个字节,取决于枚举值的个数,最多 65535 个值需要 2 个字节
SET集合类型,可以从给定的值中选择多个。SET('a', 'b', 'c')1、2、3、4 或 8 个字节,取决于集合中值的个数
BOOLEAN布尔类型,存储 TRUE 或 FALSE。TRUE1
BLOB二进制大对象类型,用于存储大量二进制数据。图片、文件等二进制数据根据实际长度定
使用方法
用户名  USERNAME varchar(50)
性别  GENDER CHAR(1)

2.sql语法

2.1基本格式:

  • 分号结尾
  • 可读性:空格缩进
  • 不区分大小写,关键字建议大写
  • 单行注释--或者#注释内容 多行注释/*   */

2.2 sql语句分类

DDL:数据定义语言,定义数据库对象:数据库,表,字段等
DML:数据操作语言,对数据表中的数据进行增删改查
DQL:数据查询语言,查询数据库中表的记录
DCL:数据控制语言,创建数据库用户,以及控制用户权限,比如增删改查的权限

 DCL语句

查询用户: USE MYSQL; SELECT * FROM USER;
创建用户:	CREATE USER '用户名'@'主机名' IDENTIFIED BY '密码';
修改用户密码: ALTER USER '用户名'@'主机名' IDENTIFIED WITH mysql_native_password BY '新密码';
删除用户:DROP USER '用户名'@'主机名';
案例练习:
-- 创建用户 itcast , 只能够在当前主机localhost访问, 密码123456;
create user 'itcast'@'localhost' identified by '123456';-- 创建用户 heima , 可以在任意主机访问该数据库, 密码123456 ;
create user 'heima'@'%' identified by '123456';-- 修改用户 heima 的访问密码为 1234 ;
alter user 'heima'@'%' identified with mysql_native_password by '1234';-- 删除itcast@localhost用户
drop user 'itcast'@'localhost';-- 查询权限
show grants for 'heima'@'%';-- 授予权限
grant all on itcast.* to 'heima'@'%';-- 撤销权限
revoke all on itcast.* from 'heima'@'%';

DDL语句

创建:		创建数据库([]可省略):CREATE DATABASE [IF NOT EXISTS] 数据库名 [DEFAULT CHARSET 字符集][COLIATE 排序规则]EX:create database test default charset utf8mb4;通常用这个字符格式,因为有的字符是四个字节,utf8只有3个字节表操作:创建表: CREATE TABLE 表名(字段1 字段1类型[COMMENT 字段1注释]字段2 字段2类型[COMMENT 字段2注释]字段3 字段3类型[COMMENT 字段3注释])[COMMENT 表的注释];EX: create table ttbb(-> id int comment '编号',-> name varchar(50) comment '姓名',-> age int comment '年龄',-> gender varchar(1) comment '性别'-> )comment '用户表';

查询:查询所有数据库:	SHOW DATABASES;查询当前数据库:  	SELECT DATABASE();使用数据库(切换数据库):	USE 数据库名查询当前数据库的所有表:	 SHOW TABLES;查询表结构: DESC 表名;查询 指定表 的 建表语句:SHOW CREATE TABLES 表名:
删除:
删除数据库:
DROP DATABASE IF EXISTS 数据库名
EX:drop database if exists test;
删除字段: ALTER TABLE  表名 DROP 字段;
删除表:DROP TABLE IF EXISTS 表名;
删除指定表并重新创建: TRUNCATE TABLE 表名;(清空数据,只留下了表)
修改:
添加字段: ALTER TABLE 表名 ADD 字段名 类型(长度) [COMMENT 注释] [约束];
修改字段名或者字段类型: ALTER TABLE 表名 CHANGE 旧字段名 新字段名 类型(长度)[COMMENT 注释] [约束];
修改表名  ALTER 表名 RENAME TO 新表名

DML语句

给指定字段添加数据: INSERT INTO 表名 (字段1,字段2····)VALUES(值1,值2····);
给全部字段添加数据:INSERT INTO 表名 VALUES(值1,值2····);
批量添加数据:INSERT INTO 表名 (字段1,字段2····)VALUES(值1,值2····),(值1,值2····),(值1,值2····)
INSERT INTO 表名 VALUES(值1,值2····),(值1,值2····),(值1,值2····);
UPDATE 表名 SET 字段名1=值1,字段名2=值2,····[WHERE 条件]
EX: UPDATE TTBB SET ID =1 WHERE NAME=233;
删除数据:DELETE FROM 表名 [WHERE 条件];

DQL语句

查询多个字段: SELET 字段1,字段2,···FROM  表名;
SELECT * FROM 表名;
设置别名:SELECT 字段1 [AS 别名],字段2 [AS 别名]···;
去除重复记录: SELECT DISTINCT 字段列表 FROM 表名;
查询指定字段: SELECT NMAE FROM TTBB;
查询所有字段: SELECT *(遵循开发规范) from emp;
不重复查询: SELECT DISTINCT ADDRESS '工作地址' FROM TTBB;(AS可省略);
条件查询:
查询年龄为10: SELECT * FROM TTBB WHERE AGE= 10;
查询年龄小于10:SELECT * FROM TTBB WHERE AGE <10;
查询没有填写身份证的人: SELECT * FROM TTBB WHERE IDCARD IS NULL;
查询有身份证的人: SELECT * FROM TTBB WHERE IDCARD I NOT NULL;
查询年龄不等于33的人;SELECT * FROM TTBB WHERE AGE !=33;(WHERE AGE <>33)
查询年龄在15-20:SELECT * FROM TTBB WHERE AGE <=20&&AGE>=15;SELECT * FROM TTBB WHERE AGE <=20 AND AGE>=15;SELECT * FROM TTBB WHERE AGE BEWTEEN 15 AND 20;(从小到大)
查询年龄为15和20:SELECT * FROM TTBB WHERE IN(15,20);
查询姓名为两个字的 SELECT * FROM TTBB WHERE NAME like '__';
查询idCARD最后为X的 SELECT * FROM TTBB WHERE IDCARD like '%X';
DQL-聚合函数:列计算统计人数  SELECT COUNT(ID/*)FROM EMP;#null不参与平均年龄 SELECT AVG(AGE) FROM TTBB;最大年龄 SELECT  MAX(AGE) FROM TTBB;最小年龄 SELECT MIN(AGE) FROM TTBB;年龄之和 SELECT  SUM(AGE) FROM TTBB WHERE ADRESS = "西安";

DQL分组查询

分组查询: SELECT 字段列表 FROM [WHERE 条件] GROUP BY 分组字段名 [HAVING 分组过滤后的条件]
根据性别分,统计男女数量: SELECT gender,COUT(*) FROM TTBB GROUP BY gender;
根据性别分组,统计男女平均年龄 SELECT gender,AVG(age) FROM TTBB GROUP BY gender;
查询年龄小于45的员工,并根据工作地址分组,获取员工数量大于等于3的工作地址:SELECT ADDRESS COUT(*) FROM ttbb WHERE AGE<=45 GROUP BY address HAVING COUT(*)>=3;

DQL排序查询

DQL-排序查询:SELECT 字段列表 FROM 表名 ORDER BY 字段1 排序方式,字段2,排序方式;
根据年龄对公司员工今昔升序排列: SELECT * FROM TTBB ORDER BY AGE ASC;
根据入职时间,降序排序 SELECT * FROM TTBB ORDER BY DATE DESC;

DQL-分页查询

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

DQL执行顺序

3.权限说明

MYSQL中定义了很多权限,常用的只有几种

4.函数

-- 字符串函数
-- concat
select concat('Hello' , ' MySQL');-- lower
select lower('Hello');-- upper
select upper('Hello');-- lpad
select lpad('01', 5, '-');-- rpad
select rpad('01', 5, '-');-- trim
select trim(' Hello  MySQL ');-- substring
select substring('Hello MySQL',1,5);-- 案例:  由于业务需求变更,企业员工的工号,统一为5位数,目前不足5位数的全部在前面补0。比如: 1号员工的工号应该为00001。
update emp set workno = lpad(workno, 5, '0');

数值函数:
-- ceil
select ceil(1.1);-- floor
select floor(1.9);-- mod
select mod(7,4);-- rand
select rand();-- round
select round(2.344,2);-- 案例: 通过数据库的函数,生成一个六位数的随机验证码。
select lpad(round(rand()*1000000 , 0), 6, '0');

 

日期函数
-- curdate()
select curdate();-- curtime()
select curtime();-- now()
select now();-- YEAR , MONTH , DAY
select YEAR(now());select MONTH(now());select DAY(now());-- date_add
select date_add(now(), INTERVAL 70 YEAR );-- datediff
select datediff('2021-10-01', '2021-12-01');-- 案例: 查询所有员工的入职天数,并根据入职天数倒序排序。
select name, datediff(curdate(), entrydate) as 'entrydays' from emp order by entrydays desc;

-- 流程控制函数
-- if
select if(false, 'Ok', 'Error');-- ifnull
select ifnull('Ok','Default');select ifnull('','Default');select ifnull(null,'Default');-- case when then else end
-- 需求: 查询emp表的员工姓名和工作地址 (北京/上海 ----> 一线城市 , 其他 ----> 二线城市)
selectname,( case workaddress when '北京' then '一线城市' when '上海' then '一线城市' else '二线城市' end ) as '工作地址'
from emp;-- 案例: 统计班级各个学员的成绩,展示的规则如下:
-- >= 85,展示优秀
-- >= 60,展示及格
-- 否则,展示不及格create table score(id int comment 'ID',name varchar(20) comment '姓名',math int comment '数学',english int comment '英语',chinese int comment '语文'
) comment '学员成绩表';
insert into score(id, name, math, english, chinese) VALUES (1, 'Tom', 67, 88, 95 ), (2, 'Rose' , 23, 66, 90),(3, 'Jack', 56, 98, 76);--
selectid,name,(case when math >= 85 then '优秀' when math >=60 then '及格' else '不及格' end ) '数学',(case when english >= 85 then '优秀' when english >=60 then '及格' else '不及格' end ) '英语',(case when chinese >= 85 then '优秀' when chinese >=60 then '及格' else '不及格' end ) '语文'
from score;

5.约束

约束:限制存储在表中的数据。

约束示例:
create table user(id int primary key auto_increment comment '主键',name varchar(10) not null unique comment '姓名',age int check ( age > 0 && age <= 120 ) comment '年龄',status char(1) default '1' comment '状态',gender char(1) comment '性别'
) comment '用户表';-- 插入数据
insert into user(name,age,status,gender) values ('Tom1',19,'1','男'),('Tom2',25,'0','男');
insert into user(name,age,status,gender) values ('Tom3',19,'1','男');insert into user(name,age,status,gender) values (null,19,'1','男');
insert into user(name,age,status,gender) values ('Tom3',19,'1','男');insert into user(name,age,status,gender) values ('Tom4',80,'1','男');
insert into user(name,age,status,gender) values ('Tom5',-1,'1','男');
insert into user(name,age,status,gender) values ('Tom5',121,'1','男');insert into user(name,age,gender) values ('Tom5',120,'男');约束 (外键) 
--准备数据
create table dept(id   int auto_increment comment 'ID' primary key,name varchar(50) not null comment '部门名称'
)comment '部门表';
INSERT INTO dept (id, name) VALUES (1, '研发部'), (2, '市场部'),(3, '财务部'), (4, '销售部'), (5, '总经办');create table emp(id  int auto_increment comment 'ID' primary key,name varchar(50) not null comment '姓名',age  int comment '年龄',job varchar(20) comment '职位',salary int comment '薪资',entrydate date comment '入职时间',managerid int comment '直属领导ID',dept_id int comment '部门ID'
)comment '员工表';INSERT INTO emp (id, name, age, job,salary, entrydate, managerid, dept_id) VALUES(1, '金庸', 66, '总裁',20000, '2000-01-01', null,5),(2, '张无忌', 20, '项目经理',12500, '2005-12-05', 1,1),(3, '杨逍', 33, '开发', 8400,'2000-11-03', 2,1),(4, '韦一笑', 48, '开发',11000, '2002-02-05', 2,1),(5, '常遇春', 43, '开发',10500, '2004-09-07', 3,1),(6, '小昭', 19, '程序员鼓励师',6600, '2004-10-12', 2,1);-- 添加外键
alter table emp add constraint fk_emp_dept_id foreign key (dept_id) references dept(id);-- 删除外键
alter table emp drop foreign key fk_emp_dept_id;-- 外键的删除和更新行为
alter table emp add constraint fk_emp_dept_id foreign key (dept_id) references dept(id) on update cascade on delete cascade ;alter table emp add constraint fk_emp_dept_id foreign key (dept_id) references dept(id) on update set null on delete set null ;

一张图看懂内外键

select * from emp , dept where emp.dept_id = dept.id; 去除多余的笛卡尔积

举例:

6.连接查询

内连接:相当于查询A、B交集部分数据
左外连接:查询左表所有数据,以及两张表交集部分数据
右外连接:查询右表所有数据,以及两张表交集部分数据
自连接:当前表与自身的连接查询,自连接必须使用表别名

左外连接:

右外连接:

自连接

union会去除重复,union all 则不会

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

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

相关文章

在海外留学/工作,如何报考微软mos认证?

重点首先得强调的是&#xff0c;即使在海外也可以顺利地在国内获取微软MOS认证&#xff01; 01 微软mos认证简介 Microsoft Office Specialist 简称MOS。是微软公司和第三方国际认证机构、全球三大IT测验与教学中心之一的思递波/Certiport公司于1997年联合推出的&#xff0c;…

python爬虫,爬取网页壁纸图片

python爬虫实战&#xff0c;爬取网页壁纸图片 使用python爬取壁纸图片&#xff0c;保存到本地。 爬取彼岸图网&#xff0c;网站地址https://pic.netbian.com/ 本人小白&#xff0c;记录一下学习过程。 开始前的准备 安装python环境&#xff0c;略。 python编辑器pycharm2…

ThinkPad T480拆机屏幕改装:便携式显示器DIY指南

ThinkPad T480拆机屏幕改装&#xff1a;便携式显示器DIY指南 本文记录了将旧笔记本电脑 T480 拆机屏幕改装为便携式显示器的全过程。作者在决定升级设备后&#xff0c;选择通过 DIY 方式利用原有的屏幕资源。文章详细介绍了屏幕驱动板的安装、螺丝孔的剪裁、排线连接及固定的步…

[AWS]RDS数据库版本升级

背景&#xff1a;由于AWS上mysql5.7版本不再支持&#xff0c;需要进行版本升级。 吐槽&#xff1a;每年都要来那么几次&#xff0c;真的有病一样&#xff0c;很烦。 步骤一、升级检查 AWS提供了一个python的升级检测脚本&#xff0c;可以按照一下脚本下载测试&#xff1a; [r…

Kibana可视化Dashboard如何基于字段是否包含某关键词进行过滤

kinana是一个功能强大、可对Elasticsearch数据进行可视化的开源工具。 我们在dashboard创建可视化时&#xff0c;有时需要将某个index里数据的某个字段根据是否包含某些特定关键词进行过滤&#xff0c;这个时候就可以用到lens里的filter功能很方便地进行操作。 如上图所示&…

架构师备考-背诵精华(系统架构评估)

系统架构评估是在对架构分析、评估的基础上&#xff0c;对架构策略的选取进行决策。它利用数学或逻辑分析技术&#xff0c;针对系统的一致性、正确性、质量属性、规划结果等不同方面&#xff0c;提供描述性、预测性和指令性的分析结果。 重要概念 敏感点&#xff1a;敏感点是…

docker 下载netcore 镜像

dotnet-docker/README.runtime.md at main dotnet/dotnet-docker GitHub docker pull mcr.microsoft.com/dotnet/runtime:8.0 docker pull mcr.microsoft.com/dotnet/runtime:3.1

二分查找算法 (算法详解+模板+例题)

文章目录 二分查找算法简介1.朴素的二分查找2. 在排序数组中查找元素的第一个和最后一个位置3. 搜索插入位置4. 山脉数组的峰顶索引5.寻找峰值6. 寻找旋转排序数组中的最小值 二分查找算法简介 二分查找算法并不是针对在数组有序的情况下,通过后面的题我们就会知道实际上只要是…

【贝加莱PLC基础教学】2.1 搜索并连接到对应的PLC(1)

【贝加莱PLC基础教学】目录大全_贝加莱plc p23 1361-CSDN博客 PLC其实和单片机差别不大&#xff0c;无非就是大一点的单片机。另外多加了一点点计算机网络和通讯知识&#xff0c;然而就是这一点点计算机网络知识让大家望而却步。 0.基础知识 在计算机网络中&#xff0c;我们通…

【MySQL】索引的机制、使用

在学习索引知识之前&#xff0c;我们可以先了解一下什么是索引。实际上&#xff0c;索引就是数据库中一个或多个列存储的结构&#xff0c;能够支持数据库管理系统在不扫描整张表的情况下也能查询到数据行&#xff0c;能够大大提升查询效率。举个例子&#xff0c;我们想要找到一…

信号与噪声分析——第一节-确定信号的分析

目录 1.确定信号的分析 1.1确定信号的分类&#xff1a; 1.周期信号与非周期信号&#xff1a; 周期信号的定义&#xff1a; 性质&#xff1a; 2.能量信号与功率信号&#xff1a; 定义 区别&#xff1a; 3.基带信号与频带信号&#xff1a; 基带信号的定义&#xff1a; …

【RabbitMQ】RabbitMQ 的七种工作模式介绍

目录 1. Simple(简单模式) 2. Work Queue(工作队列) 3. Publish/Subscribe(发布/订阅) 4. Routing(路由模式) 5. Topics(通配符模式) 6. RPC(RPC通信) 7. Publisher Confirms(发布确认) 上一篇文章中我们简单认识了RabbitM1: 【RabbitMQ】RabbitMQ 的概念以及使用Rabb…

IO编程——消息队列

题目&#xff1a; 代码实现&#xff1a; #include <myhead.h> //正文大小 #define MSGSZ (sizeof(struct msgbuf)-sizeof(long)) //定义要发送的消息类型 struct msgbuf{long msgtype; //消息类型char mtext[1024]; //消息正文 };int main(int argc, const char *ar…

linux下建立软链接

深度学习训练中经常会遇到数据量庞大或者工程中模型报错太多导致磁盘空间不够&#xff0c;但是又不想修改原来在代码中写的路径&#xff0c;这个时候制作软连接很有作用&#xff0c;把占用量大的目录移到别的空闲磁盘&#xff0c;然后在原来的目录做一个软连接指向那个移到的空…

k8s ETCD数据备份与恢复

在 Kubernetes 集群中&#xff0c;etcd 是一个分布式键值存储&#xff0c;它保存着整个集群的状态&#xff0c;包括节点、Pod、ConfigMap、Secrets 等关键信息。因此&#xff0c;定期对 etcd 进行备份是非常重要的&#xff0c;特别是在集群发生故障或需要恢复数据的情况下。本文…

Java--集合(三)之vectorlinkedlisthashset结构

文章目录 0.架构图1.vector解析2.LinkedList分析2.1源码分析2.2迭代器遍历的三种方式 3.set接口的使用方法3.1基本使用说明3.2基本遍历方式3.3HashSet引入3.4数组链表模拟3.5hashset扩容机制3.6hashset源码解读3.7扩容*转成红黑树机制**我的理解 0.架构图 1.vector解析 和之前介…

【Vue】Vue3.0(十四)接口,泛型和自定义类型的概念及使用

上篇文章&#xff1a; 【Vue】Vue3.0&#xff08;十三&#xff09;中标签属性ref&#xff08;加在普通标签上、加在组件标签上&#xff09;、局部样式 &#x1f3e1;作者主页&#xff1a;点击&#xff01; &#x1f916;Vue专栏&#xff1a;点击&#xff01; ⏰️创作时间&…

数据结构——二叉树的基本操作及进阶操作

前言 介绍 &#x1f343;数据结构专区&#xff1a;数据结构 参考 该部分知识参考于《数据结构&#xff08;C语言版 第2版&#xff09;》116 ~ 122页 及 《数据结构教程》201 ~ 213页 重点 树的基本实现并不难&#xff0c;重点在于对递归的理解才是树这部分知识带来的最大收…

python绝对值怎么表示

python abs()函数用于获取数字的绝对值&#xff0c;参数可以是负数、正数、浮点数或者长整形。 语法&#xff1a; abs( x ) 下面是详细参数&#xff1a; X&#xff1a;这是一个数值表达式。 返回值&#xff1a; x的绝对值。 例如&#xff1a; #!/usr/bin/python print &q…

smbms(2)

目录 一、修改密码功能实现 二、优化密码修改&#xff0c;加入旧密码确认环节【使用Ajax】 三、用户管理实现 获取用户数量 获取用户列表 获取角色列表 Servlet 一、修改密码功能实现 1、导入前端素材 2、UserDao接口 3、UserDaoImpl实现类 4、UserService接口 5、Us…