一杯茶,带你了解MySQL连接器

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS MySQL,高可用系列 2核4GB
简介: 一杯茶,带你了解MySQL连接器

MySQL连接器的介绍

首先我们需要先知道MySQL连接器是什么?


mysql 的 连接器 是msyql server层的第一个模块。


我们还需要知道他的作用是什么?


负责跟客户端建立连接、获取权限、维持和管理连接。


具体步骤:


TCP三次握手建立连接

连接器开始认证身份

相信一般在学过Java的小伙伴都应该知道mysql-connector-java—是Java操作MySQL的一种MySQL连接器。


通过它我们能编写Java的代码来进行对MySQL的操作,以便一些项目的使用!

image.png



MySQL连接器的作用

因为一些时间原因我就给大家介绍MySQL连接器 - 使用JDBC的CallableStatements来执行存储过程。


首先创建存储过程demoSp:


CREATE PROCEDURE demoSp(IN inputParam VARCHAR(255),  INOUT inOutParam INT) 
BEGIN 
DECLARE z INT; 
SET z = inOutParam + 1; 
SET inOutParam = z; 
SELECT inputParam; 
SELECT CONCAT('zyxw', inputParam); 
END


通过上面这段代码我们可以这样理解:IN后跟输入参数,INOUT后面跟的是输出参数。


我们一般使用Java的MySQL连接器来存储是是来对demoSp的调用,那具体是怎么调用的呢?


1.使用 Connection.prepareCall() 来准备调用语句。如下:


CallableStatement cStmt = conn.prepareCall("{call demoSp(?, ?)}"); 
//下标是从1开始,第一个参数是输入参数 
//这句是给第一个参数赋初值 
cStmt.setString(1, "abcdefg");


2、注册输出参数(如果有)


输出参数是在创建存储过程时,用OUT或INOUT修饰过的变量.


// 以下两种方式均可 
// 1、注册输出参数,第二个参数是用INOUT修饰过 
cStmt.registerOutParameter(2, Types.INTEGER); 
// 2、也可以使用这种方式进行注册参数,直接用参数变量名,而不是使用索引。 
cStmt.registerOutParameter("inOutParam", Types.INTEGER);


3、注册输入参数


通过索引,设置参数 
cStmt.setString(1, "abcdefg");  
// 也可以使用名字来设置一个参数 
cStmt.setString("inputParam", "abcdefg"); 
// 使用索引设置'in/out'参数 
cStmt.setInt(2, 1); 
// 也可以使用名字来设置'in/out'参数 
cStmt.setInt("inOutParam", 1);


4、执行 CallableStatement ,检索任何结果集或输出参数。


尽管 CallableStatement 支持调用任意的执行方法


( executeUpdate() , executeQuery() 或 execute() ),最灵活的方法是 execute() ,


因为你不需要提前知道存储过程是否返回结果集。


......
 boolean hadResults = cStmt.execute();
 while (hadResults) { 
 ResultSet rs = cStmt.getResultSet(); 
 // 处理结果集 
 . ... 
 hadResults = cStmt.getMoreResults(); 
 } 
// 检索输出参数 
// Connector/J支持基本索引和基于名字来检索 
int outputValue = cStmt.getInt(2); // 基于索引 
outputValue = cStmt.getInt("inOutParam"); // 基于名字
......





相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
2月前
|
关系型数据库 MySQL 网络安全
DBeaver连接MySQL提示Access denied for user ‘‘@‘ip‘ (using password: YES)
“Access denied for user ''@'ip' (using password: YES)”错误通常与MySQL用户权限配置或网络设置有关。通过检查并正确配置用户名和密码、用户权限、MySQL配置文件及防火墙设置,可以有效解决此问题。希望本文能帮助您成功连接MySQL数据库。
216 4
|
2月前
|
安全 关系型数据库 MySQL
【赵渝强老师】MySQL的连接方式
本文介绍了MySQL数据库服务器启动后的三种连接方式:本地连接、远程连接和安全连接。详细步骤包括使用root用户登录、修改密码、创建新用户、授权及配置SSL等。并附有视频讲解,帮助读者更好地理解和操作。
353 1
|
3月前
|
SQL Java 关系型数据库
java连接mysql查询数据(基础版,无框架)
【10月更文挑战第12天】该示例展示了如何使用Java通过JDBC连接MySQL数据库并查询数据。首先在项目中引入`mysql-connector-java`依赖,然后通过`JdbcUtil`类中的`main`方法实现数据库连接、执行SQL查询及结果处理,最后关闭相关资源。
317 6
|
3月前
|
SQL JavaScript 关系型数据库
node博客小项目:接口开发、连接mysql数据库
【10月更文挑战第14天】node博客小项目:接口开发、连接mysql数据库
|
3月前
|
Java 关系型数据库 MySQL
【编程基础知识】Eclipse连接MySQL 8.0时的JDK版本和驱动问题全解析
本文详细解析了在使用Eclipse连接MySQL 8.0时常见的JDK版本不兼容、驱动类错误和时区设置问题,并提供了清晰的解决方案。通过正确配置JDK版本、选择合适的驱动类和设置时区,确保Java应用能够顺利连接MySQL 8.0。
336 1
|
3月前
|
Java 关系型数据库 MySQL
springboot学习五:springboot整合Mybatis 连接 mysql数据库
这篇文章是关于如何使用Spring Boot整合MyBatis来连接MySQL数据库,并进行基本的增删改查操作的教程。
481 0
springboot学习五:springboot整合Mybatis 连接 mysql数据库
|
4月前
|
SQL 关系型数据库 MySQL
MySQL C连接与使用
【9月更文挑战第21天】在 MySQL 中,可以通过 C 语言连接和操作数据库。首先需安装 MySQL 服务器及 C 开发库,然后在程序中包含必要头文件,初始化连接对象,并使用实际参数建立连接。执行 SQL 语句时,需替换表名等变量,获取并遍历结果集。最后,释放资源并关闭连接。过程中应注意错误处理、内存管理和安全性,以及性能优化。此方式适用于高效数据存储和检索的应用程序。
|
3月前
|
SQL JavaScript 关系型数据库
Node.js 连接 MySQL
10月更文挑战第9天
51 0
|
4月前
|
SQL JavaScript 关系型数据库
Node服务连接Mysql数据库
本文介绍了如何在Node服务中连接MySQL数据库,并实现心跳包连接机制。
59 0
Node服务连接Mysql数据库
|
3月前
|
关系型数据库 MySQL Linux
Navicat 连接 Windows、Linux系统下的MySQL 各种错误,修改密码。
使用Navicat连接Windows和Linux系统下的MySQL时可能遇到的四种错误及其解决方法,包括错误代码2003、1045和2013,以及如何修改MySQL密码。
422 0