MySQL数据库连接查询和存储过程

news2024/11/23 15:22:38

MySQL数据库连接查询和存储过程

  • 一、连接查询
    • 1、内连查询
    • 2、左连接
    • 3、右链接
  • 二、存储过程
    • 1、存储过程简介
    • 2、存储过程的优点
    • 3、语法
      • 3.1 参数分类
      • 3.2 不加参数的存储过程
      • 3.3 带参数的存储过程
      • 3.4删除存储过程
      • 3.5 事务和存储过程有什么区别?
  • 三、总结
    • 1、连接查询
    • 2、存储过程

一、连接查询

mysql的连接查询,通常都是将来自两个或多个表的记录行结合起来,基于这些表之间的共同字段,进行数据的拼接

首先,要确定一个主表作为结果集,然后将其他表的行有选择性的连接到选定的主表结果上,使用较多的连接查询包括:内连接(子查询)、左连接和右连接(外连)

下面的实验,均已以一下两个表进行实验

6751(1)(1)

1、内连查询

mysql中的内连接就是两张或多张中同时符合某种条件的数据记录的组合,通常在from子句中使用关键字inner join 来连接多张表,并使用on子句设置连接条件,内连接是系统默认的表连接,所以在from子句后可以省略inner 关键字,值使用关键字join。

同时有多个表时,也可以联系使用inner join来实现多表的内连接,不过为了更好的性能,建议最好不要超过三个表。

同时有多个表时,也可以联系使用inner join来实现多表的内连接,不过为了更好的性能,建议最好不要超过三个表。
select info.name,info.score from info inner join info2 on info.name=info2,name;
#查询info表和info2表中name相同的行,只显示,info表中的name和score字段数据

6752(1)(1)

6753(1)(1)

2、左连接

左连接也可以被称为左外连接, 在from子句中使用left join 或者 left outer join 关键字来表示

左连接以左侧表为基础表,接收左表的所有行,并用这些行与右侧参考中的记录进行匹配,也就是说 匹配左表的所有行以及右表中符合条件的行。

select * from info left join info2 on info.name=info2.name;
#左表的内容将全部显示,右表只会显示与左表共同字段的记录,当右表没有数据将与null显示

6754(1)(1)

3、右链接

右连接也称为右外连接,在from子句中使用right join 或者right outer join 关键字来表示。右连接跟左连接正好相反,它是以右表为基础表,用于接收右表中所有行,并用这些记录与左表中的行进行匹配。

select * from info right join info2 on info.name=info2.name;
#右表全部的内容显示,左表只显示相同字段的记录,左表不足的地方以null显示

6755(1)(1)

二、存储过程

1、存储过程简介

存储过程与函数的直接效果类似,只不过存储过程,封装的是一组sql语句。

  • mysql数据库过程是一组为了完成特定功能的sql语句的集合。

  • 存储过程这个功能时从5.0版本才开始支持的,它可以加快数据库的处理速度,增强数据库在实际应用中的灵活性。

  • 存储过程在使用过程中是将常用或复杂的工作预先使用sql语句写好,并用一个指定的名称存储起来,这个过程编译和优化后存储在数据库服务器中,当需要使用该存储过程时,只需要调用它即可。

  • 操作数据库的传统sql语句在执行时,需要先编译,然后再去执行,跟存储过程一对比,明显存储过程在执行速度更快,效率更高。存储过程在数据库中创建并保存。它不仅仅是sql了语句的集合,还可以加入一些特殊的控制结构,也可以控制数据的访问方式。

2、存储过程的优点

  • 执行一次后,会将生成的二进制代码驻留缓冲区,提高执行效率
  • sql语句加上控制语句的集合,灵活性高
  • 在服务器端存储,客户端调用时,降低网络负载
  • 可多次重复被调用,可随时修改,不影响客户端调用。
  • 可完成所有的数据库操作,也可控制数据库的信息访问权限

3、语法

create procedure  <过程名> ([过程参数....]) <过程体>
[过程参数....] 格式
<过程名>:尽量避免与内置的函数或字段重名
<过程体>:语句
[in|out|inout] <参数名><类型>

3.1 参数分类

存储过程的主题部分,即过程体

以begin 开始,end结束,若只有一条sql语句,可省略begin 和end

以delimiter 开始和结束

3.2 不加参数的存储过程

delimiter @@    ##将语句的结束符号从分号临时修改为@@,以防出问题,可以自定义

create proceduer  ydq()  #创建存储过程,过程自定义,()可带参数 
begin              #过程体以关键字begin开始
select * from info;    #过程体语句(可有多条)
end @@             #过程体以关键字end结尾

delimiter ;        #将语句的结束符号恢复为分号

show create proceduer ydq\G
#查看存储过程信息

call ydq();   #调用存储过程

以下面两个表,写出内连查询的存储过程

6756(1)(1)

6757(1)(1)

3.3 带参数的存储过程

in输入参数: in 表示调用者向过程传入值(传入值可以是字面量或变量)

out输出参数: out表示过程向调用者传出值(可以返回多个值)(传出值只能是变量)

inout输入/输出参数: inout,即表示调用者向过程传入值,又表示过程向调用者传入值(只能是变量)

delimiter $$
create procedure ydq01(in inname varchar(40))
begin
create table if not exists ydq(id int(4),name varchar(40),score decimal(5,2));
insert into ydq values(1,'zhangsan',100),(2,'lisi',99);
select * from ydq where name=inname;
end $$
delimiter ;
call ydq01('lisi')

6758(1)(1)

6759(1)(1)

3.4删除存储过程

drop procedure if exists ydq;
#删除ydq存储过程

6760(1)(1)

3.5 事务和存储过程有什么区别?

事务

  • 实际而言,是存储引擎的特性
  • 目的性: 事务,是为了保证数据的一致性、完整性、原子性、持久性(ACID)

存储过程

  • 存储过程中,包含了事务。(要看具体的存储引擎,因为myisam不支持事务)
  • 存储过程的目的性: 简化复杂性操作

减少数据库资源消耗

可以通过传参,方便、灵活的进行sql查询类操作

三、总结

1、连接查询

连接查询分为内连查询和左查询、右查询。

内连接:使用inner join 连接不同的表,显示的数据为左右表都同时满足的条件

左连接: 使用left join 连接不同的表,以左表为基础显示,去匹配右表显示满足条件的记录

右连接: 使用 right joi 连接不同的表,以右表为基础显示,去匹配左表显示满足条件的记录

2、存储过程

存储过程是将一些sql语句存储在集合里面,当需要执行这些语句的时候,就可进行call调用这个存储过程,整体逻辑跟shell中函数一致。

主要可避免提高执行sql语句的效率、提高灵活率。

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

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

相关文章

【Java项目中 利用Redis实现数据缓存】

文章目录 Java SpringBoot项目中 用Redis实现数据缓存1 环境搭建1.1 maven坐标1.2 配置文件1.3 配置类 2 实现缓存短信验证码3 缓存菜品数据4 Spring Cache 缓存框架4.1 Spring Cache介绍4.2 Spring Cache常用注解4.3 Spring Cache使用方式 Java SpringBoot项目中 用Redis实现数…

一文了解Moonbeam互连合约

什么是互连合约Connected Contracts 简单来说&#xff0c;互连合约是通过Moonbeam连接其他区块链上的一个或多个智能合约&#xff0c;其允许目标链上的用户通过跨链消息传递协议在一个应用中操作不同链上的资产或是服务。 通过互连合约方案&#xff0c;不同迥异的公链技术架构…

计算机内部总线详解

文章目录 总线概述地址总线位宽 数据总线位宽CPU性能指标 例题 总线概述 众所周知&#xff0c;总线就是用来帮助连接两个或多个计算机组件&#xff0c;用于数据传输&#xff0c;计算机内部存在三种类型的总线&#xff1a; 地址总线&#xff1a;用于传输指示计算机中的内存或外…

【uboot1】常用指令

文章目录 1.U-Boot命令之常用命令&#xff1a;7.U-Boot命令之EMMC和SD卡操作命令&#xff1a;一般EMMC和SD卡是同一个东西&#xff0c;没特殊说明&#xff0c;统一MMC来代指EMMC和SD卡8.U-Boot命令之内存操作命令&#xff1a;直接对DRAM进行读写操作&#xff0c;uboot命令中的数…

MySQL数据库高级查询语句

MySQL数据库高级查询语句 一、语句SELECT ----显示表格中一个或数个字段的所有数据记录DISTINCT ----不显示重复的数据记录WHERE ----有条件查询AND OR ----且 或IN ----显示已知的值的数据记录BETWEEN ----显示两个值范围内的数据记录通配符 ----通常通配符都是跟 LIKE 一起使…

强化学习从基础到进阶-案例与实践[5]:梯度策略、添加基线(baseline)、优势函数、动作分配合适的分数(credit)

【强化学习原理项目专栏】必看系列&#xff1a;单智能体、多智能体算法原理项目实战、相关技巧&#xff08;调参、画图等、趣味项目实现、学术应用项目实现 专栏详细介绍&#xff1a;【强化学习原理项目专栏】必看系列&#xff1a;单智能体、多智能体算法原理项目实战、相关技巧…

解决关于msvcp120.dll丢失的问题(解决方法)

msvcp120.dll是微软软件包的一部分。它是一个库文件&#xff0c;可用于支持软件运行时&#xff0c;msvcp120.dll的作用是提供计算机程序所需的标准库&#xff0c;msvcp120.dll还负责管理堆内存、线程和异常处理函数等。在使用windows编写的应用程序中&#xff0c;通常需要使用此…

【新星计划·2023】Linux系统的架构和组件讲解

作者&#xff1a;Insist-- 个人主页&#xff1a;insist--个人主页 作者会持续更新网络知识和python基础知识&#xff0c;期待你的关注 前言 本文将讲解Linux系统的架构和组件。 目录 一、Linux系统的架构 1、硬件层 2、内核层 3、进程管理子系统 4、内存管理子系统 5、…

JDBC和数据库应用总结

文章目录 1. JDBC介绍2. 相关jar包引入3. JDBC与数据库基本连接4. JDBC API 详解4.1 Connection 接口4.2 Statement 接口4.3 ResultSet 5. PreparedStatement 详解 1. JDBC介绍 JDBC是一套标准接口&#xff0c;这套接口用于操作所有的数据库&#xff0c;不同的数据库厂商对迎合…

在C#下运行Python:IronPython和Pythonnet

在C#下运行Python可能有不同的原因。其中一些原因包括&#xff1a; 使用C#应用程序中不可用的特定Python功能或库。结合Python的简单性和表现力以及C#的性能和稳健性&#xff0c;完成不同任务。与基于Python的系统或服务进行集成。 为实现Python和C#之间的互操作性&#xff0…

Java日志框架介绍

​今天来聊一聊 Java 日志框架&#xff0c;不管是在项目开发阶段的调试&#xff0c;还是项目上线后的运行&#xff0c;都离不开日志。日志具有处理历史数据、定位程序问题、理解程序运行过程等重要作用。在 Spring 项目开发过程中我们常见的日志框架可能就是 logback、log4j2 和…

Go学习圣经:Go语言实现高并发CRUD业务开发

说在前面&#xff1a; 现在拿到offer超级难&#xff0c;甚至连面试电话&#xff0c;一个都搞不到。 尼恩的技术社群中&#xff08;50&#xff09;&#xff0c;很多小伙伴凭借 “左手云原生右手大数据”的绝活&#xff0c;拿到了offer&#xff0c;并且是非常优质的offer&#…

APP/小程序嵌入游戏,游戏飞跃的赛道

APP/小程序接入游戏运营已不是新鲜事&#xff0c;然而&#xff0c;其仍具有巨大的发展潜力&#xff0c;尤其是社交类APP&#xff0c;多以加入娱乐游戏增加互动&#xff0c;获取目标客户&#xff0c;同时为产品增加变现渠道&#xff0c;实现双赢。 对于APP嵌入式游戏&#xff0…

Java之SpringCloud Alibaba【一】【Nacos一篇文章精通系列】

Java之SpringCloud Alibaba【一】【Nacos一篇文章精通系列】 一、微服务介绍1、系统架构演变1&#xff09;单体应用架构2&#xff09;垂直应用架构3&#xff09;分布式4&#xff09;SOA架构5&#xff09;微服务框架6&#xff09;常见微服务架构 2、SpringCloud Alibaba介绍3、S…

【C语言督学训练营 第十四天】二叉树真题实战 ----- 层序建树、前中后序遍历、求树的WPL

文章目录 前言树概念二叉树层序建树四种遍历二叉树的方式层次遍历前序遍历中序遍历后续遍历 真题实战&#xff01; 前言 今天进行总结的是考研408有关二叉树的基础知识&#xff0c;是王道C语言督学营的第十四天&#xff0c;随着课程的深入&#xff0c;代码实战的难度慢慢的上来…

MyCat01——如何实现MySQL中的主从复制

1 问题 数据对于我们来说是一项最重要的资产&#xff0c;因为数据丢失带来的损失&#xff0c;对于一家公司来说&#xff0c;有时也是毁灭性的。 那么如何确保数据安全&#xff0c;不因断电或系统故障带来数据丢失呢&#xff1f; 当用户增加&#xff0c;对数据库的访问量也随…

推荐一款好用的时序预测工具——Alibaba DChain Forecast

前言 绝大部分行业场景&#xff0c;尤其是互联网、量化行业&#xff0c;每天都会产生大量的数据。金融领域股票价格随时间的走势&#xff1b;电商行业每日的销售额&#xff1b;旅游行业随着节假日周期变化的机票酒店价格等。我们称这种不同时间收到的&#xff0c;描述一个或多…

Ajax技术的秘密揭秘:异步传输,高效交互

文章目录 I. 什么是AjaxAjax的定义和起源Ajax与传统的Web应用程序之间的区别 II. Ajax的工作原理Ajax的基本原理Ajax如何通过异步传输实现无需刷新页面 III. Ajax的应用场景在Web应用程序中应用Ajax的优势Ajax在哪些场景中使用 IV. Ajax的组成部分和APIXHR对象FormData对象Fetc…

用postman进行web端自动化测试

目录 前言 一、抓包&#xff08;使用Charles抓包工具&#xff09; 二、选择请求方法 三、填写url地址 四、填写Header 五、填写body 六、断言&#xff08;Tests页&#xff09; 七、获取动态参数——例如token 八、设置静态参数&#xff08;请求地址、账号密码等&#x…

【Django-功能优化】存储、循环、操作选择对代码性能的影响

功能开发背景 港口货轮需要进行集装箱的装卸任务&#xff1a; 船上的每一个集装箱&#xff0c;可以用三个维度的坐标来唯一定位&#xff1a;(bay, column, layer)&#xff0c;这三个维度结合其他一些固有信息&#xff0c;构成了一个箱子的字段属性&#xff0c;存储在箱子数据表…