MySQL学习整理

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 2核4GB
简介: MySQL学习整理

主页:写程序的小王叔叔的博客欢迎来访👀

支持:点赞收藏关注


1 数据库将表中注释显示到界面

SHOW FULL COLUMNS FROM + 数据库中任意表名

2 数据库 触发器

触发器

  其是一种特殊的存储过程。一般的存储过程是通过存储过程名直接调用,而触发器主要是通过事件(增、删、改)进行触发而被执行的。其在表中数据发生变化时自动强制执行。

常见的触发器有两种:after(for)、instead of,用于insert、update、delete事件。

  after(for) 表示执行代码后,执行触发器

  instead of 表示执行代码前,用已经写好的触发器代替你的操作

触发器语法

create trigger 触发器的名字 on 操作表
  for|after instead of
  update|insert|delete  as

触发器实现原理图

image.png

触发器示例

Example1

--禁止用户插入数据(实际上是先插入,然后立刻将其删除!)  create trigger tr_insert on bank
  for         --for表示执行之后的操作  insert--即先执行了插入操作,同时在临时表中保存了插入记录  as--执行完插入之后,在新生成的表中将刚刚插入的那条记录删除,--而此时得到的刚刚插入的记录的id是通过临时表 inserted得到的  delete*from bank where cid=(select cid from inserted)  生成上面的触发器后,当用户再输入insert语句后就见不到效果了!
  如:insert into bank values('0004',10000),是插入不进数据库的。

Example2


--删除谁就让谁的账户加上10元  create trigger tr_dalete on bank
  instead of
  delete  as  update bank balance=balance+10where cid=(select cid from deleted)

 生成这个触发器之后,当用户输入delete语句后,对应的那个id不但没有被删除掉,而且他的账户增加了10元

 如:delete from bank where cid='0002',执行完这句话后,编号为0002的账户会增加10元

3 数据库 存储过程

存储过程(Stored Procedure)是在大型数据库系统中,一组为了完成特定功能的SQL 语句集,存储在数据库中,经过第一次编译后再次调用不需要再次编译,用户通过指定存储过程的名字并给出参数(如果该存储过程带有参数)来执行它。存储过程是数据库中的一个重要对象,任何一个设计良好的数据库应用程序都应该用到存储过程.

一、存储过程与函数的区别

 1.一般来说,存储过程实现的功能要复杂一点,而函数的实现的功能针对性比较强。

 2.对于存储过程来说可以返回参数(output),而函数只能返回值或者表对象。

 3.存储过程一般是作为一个独立的部分来执行,而函数可以作为查询语句的一个部分来调用,由于函数可以返回一个表对象,因此它可以在查询语句中位于FROM关键字的后面。

二、存储过程的优点

 1.执行速度更快 – 在数据库中保存的存储过程语句都是编译过的

 2.允许模块化程序设计 – 类似方法的复用

 3.提高系统安全性 – 防止SQL注入

 4.减少网络流通量 – 只要传输存储过程的名称

系统存储过程一般以sp开头,用户自定义的存储过程一般以usp开头

三、定义存储过程语法

"["   里面的内容表示可选项
  create proc 存储过程名
  @参数1        数据类型 [=默认值][output],  @参数2        数据类型 [=默认值][output],  ...
  as  SQL语句

 四、简单的一个例子

 

定义存储过程:
  create proc usp_StudentByGenderAge
  @gender nvarchar(10)[='男'],  @age int[=30]  as  select*from MyStudent where FGender=@gender and FAge=@age
 执行存储过程:
  Situation One(调用默认的参数):  exec usp_StudentByGenderAge
  Situation Two(调用自己指定的参数):  exec usp_StudentByGenderAge '女',50  或者指定变量名        exec usp_StudentByGenderAge @age=50,@gender='女' 对存储过程进行修改
  alter proc usp_StudentByGenderAge
  @gender nvarchar(10)[='男'],  @age int[=30],  --加output表示该参数是需要在存储过程中赋值并返回的  @recorderCount int output 
  as  select*from MyStudent where FGender=@gender and FAge=@age
  set @recorderCount=(selectcount(*)from MyStudent where FGender=@gender and FAge=@age)--output参数的目的,就是调用者需要传递一个变量进来,然后在存储过程中为该变量完成赋值工作,存储过程执行完成以后,将执行的对应结果返回给传递进来的变量。(与C#中的out原理一模一样)

调用(记住这里的语法!)因为该存储过程前面还有其他参数,所以要把 @recorderCount写上,该存储过程执行后,相当与完成了以上的查询工作,同时将查询结果得到的条数赋值给了@count变量。(@count是当做参数传给usp_StudentByGenderAge,当存储过程执行完毕以后,将得到的条数返回给@count)

declare @count int  exec usp_StudentByGenderAge @recorderCount=@count output
  print @count

4 win7彻底卸载mysql

win7下面完全删除mysql

1、mysql在windows 7 下还暗藏了一招,在C盘的ProgramData文件夹下还有一个MYSQL文件夹,通常这个ProgramData是隐藏文件,需要通过设置显示出来 (这个不再熬述),在里面会发现MYSQL的文件夹,通常当按照网上的方法删除干净之后,这个文件夹是还存在的。

2、到控制面板里面先把mysql删除.  

3、到c盘C:\Program Files目录下把mysql目录删除. (这个目录是你之前mysql的安装目录,你可能在d盘什么的)

4、如果在其他盘还有设置目录也要删除.空目录也要删除

5、到regedit把注册表

HKEY_LOCAL_MACHINE/SYSTEM/ControlSet001/Services/Eventlog/Applications/MySQL

HKEY_LOCAL_MACHINE/SYSTEM/ControlSet002/Services/Eventlog/Applications/MySQL

HKEY_LOCAL_MACHINE/SYSTEM/CurrentControlSet/Services/Eventlog/Applications/MySQL

有的话全部删除mysql文件(技巧:用F3循环查找“mysql”);

最后如果删除卸载干净后会提示:卸载删除干净的类似提示弹出框

如果是windows 7 的系统,还需要找到C:\ProgramData\MYSQL将其删除;完成,即可再次安装,不需要重启系统;

5 10个简单步骤,完全理解SQL

1、 SQL 是一种声明式语言

2、 SQL 的语法并不按照语法顺序执行

SQL 语句的语法顺序是:

  • SELECT[DISTINCT]
  • FROM
  • WHERE
  • GROUP BY
  • HAVING
  • UNION
  • ORDER BY

其执行顺序为:

  • FROM【1、 FROM 才是 SQL 语句执行的第一步】
  • WHERE
  • GROUP BY
  • HAVING
  • SELECT【2、 SELECT 是在大部分语句执行了之后才执行的,严格的说是在 FROM 和GROUP BY 之后执行的】
  • DISTINCT
  • UNION【3、 无论在语法上还是在执行顺序上, UNION 总是排在在 ORDER BY 之前】
  • ORDER BY

3、 SQL 语言的核心是对表的引用(table references)

4、 灵活引用表能使 SQL 语句变得更强大

一个简单的例子就是 JOIN 的使用。一种特殊的表引用语句。

5、 SQL 语句中推荐使用表连接

给你忠告:尽量不要使用逗号来代替 JOIN 进行表的连接,这样会提高你的 SQL 语句的可读性,并且可以避免一些错误

记着要尽量使用 JOIN 进行表的连接,永远不要在 FROM 后面使用逗号连接表

6、 SQL 语句中不同的连接操作

SQL 语句中,表连接的方式从根本上分为五种

  • EQUI JOIN
  • SEMI JOIN
  • ANTI JOIN
  • CROSS JOIN
  • DIVISION

EQUI JOIN

这是一种最普通的 JOIN 操作,它包含两种连接方式:

  • INNER JOIN(或者是 JOIN )
  • OUTER JOIN(包括: LEFT 、 RIGHT、 FULL OUTER JOIN)

SEMI JOIN

这种连接关系在 SQL 中有两种表现方式:使用 IN,或者使用 EXISTS。

ANTI JOIN

这种连接的关系跟 SEMI JOIN 刚好相反。在 IN 或者 EXISTS 前加一个 NOT 关键字就能使用这种连接

内联合(inner join)只生成同时匹配表A和表B的记录集。(如下图)

image.png


全外联合(full outer join)生成表A和表B里的记录全集,包括两边都匹配的记录。如果有一边没有匹配的,缺失的这一边为null。(如下图)

image.png

左外联合(left outer join)生成表A的所有记录,包括在表B里匹配的记录。如果没有匹配的,右边将是null。(如下图)


image.png

image.png

7、 SQL 中如同变量的派生表

8、 SQL 语句中 GROUP BY 是对表的引用进行的操作

9、 SQL 语句中的 SELECT 实质上是对关系的映射

SELECT 语句有很多特殊的规则,至少你应该熟悉以下几条

  1. 你仅能够使用那些能通过表引用而得来的字段;
  2. 如果你有 GROUP BY 语句,你只能够使用 GROUP BY 语句后面的字段或者聚合函数;
  3. 当你的语句中没有 GROUP BY 的时候,可以使用开窗函数代替聚合函数;
  4. 当你的语句中没有 GROUP BY 的时候,你不能同时使用聚合函数和其它函数;
  5. 有一些方法可以将普通函数封装在聚合函数中;

10、 SQL 语句中的几个简单的关键词:

DISTINCT , UNION , ORDER BY , OFFSET

⚠️注意 ~

💯本期内容就结束了,如果内容有误,麻烦大家评论区指出!

如有疑问❓可以在评论区留言💬或私信留言💬,尽我最大能力🏃‍♀️帮大家解决👨‍🏫!

如果我的文章有帮助到您,欢迎点赞+关注✔️鼓励博主🏃,您的鼓励是我分享的动力🏃🏃🏃~

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
1月前
|
分布式计算 关系型数据库 MySQL
大数据-88 Spark 集群 案例学习 Spark Scala 案例 SuperWordCount 计算结果数据写入MySQL
大数据-88 Spark 集群 案例学习 Spark Scala 案例 SuperWordCount 计算结果数据写入MySQL
48 3
|
5月前
|
SQL 关系型数据库 MySQL
关于MySQL数据库的学习指南总结
【6月更文挑战第17天】MySQL是流行的关系型DBMS,适合各种应用。学习要点包括安装配置、数据类型、SQL(如SELECT、INSERT)、关系模型、表设计、SQL查询(如WHERE、ORDER BY)、事务处理、用户管理、性能优化和高级技术如存储过程、触发器。了解ACID特性,使用索引和内存优化提升性能,通过备份恢复确保数据安全。不断学习新技术以提升技能。
91 3
|
1月前
|
关系型数据库 MySQL Java
Django学习二:配置mysql,创建model实例,自动创建数据库表,对mysql数据库表已经创建好的进行直接操作和实验。
这篇文章是关于如何使用Django框架配置MySQL数据库,创建模型实例,并自动或手动创建数据库表,以及对这些表进行操作的详细教程。
61 0
Django学习二:配置mysql,创建model实例,自动创建数据库表,对mysql数据库表已经创建好的进行直接操作和实验。
|
1月前
|
Java 关系型数据库 MySQL
springboot学习五:springboot整合Mybatis 连接 mysql数据库
这篇文章是关于如何使用Spring Boot整合MyBatis来连接MySQL数据库,并进行基本的增删改查操作的教程。
57 0
springboot学习五:springboot整合Mybatis 连接 mysql数据库
|
1月前
|
Java 关系型数据库 MySQL
springboot学习四:springboot链接mysql数据库,使用JdbcTemplate 操作mysql
这篇文章是关于如何使用Spring Boot框架通过JdbcTemplate操作MySQL数据库的教程。
22 0
springboot学习四:springboot链接mysql数据库,使用JdbcTemplate 操作mysql
|
1月前
|
关系型数据库 MySQL 数据库
mysql关系型数据库的学习
mysql关系型数据库的学习
18 0
|
1月前
|
Kubernetes 关系型数据库 MySQL
k8s学习--利用helm部署应用mysql,加深helm的理解
k8s学习--利用helm部署应用mysql,加深helm的理解
166 0
|
2月前
|
SQL 关系型数据库 MySQL
学习MySQL操作的有效方法
学习MySQL操作的有效方法
43 3
|
2月前
|
SQL 关系型数据库 MySQL
如何学习 MySQL?
如何学习 MySQL?
37 3
|
3月前
|
SQL 关系型数据库 MySQL
学习mysql基础操作
【8月更文挑战第20天】学习mysql基础操作
40 1