【MySQL】JDBC编程

【MySQL】JDBC编程

一、驱动程序包

1. 特性

1.1 底层差异情况

不同的应用程序在编写代码时采用的编程模式存在差异,所以为编程语言代码操作层面所设计的驱动包内类与接口的范式会因对应底层程序代码的不同而有所不同。

1.2 JDBC接口的一致性

在数据库相关应用程序中,Java规定必须使用Java设计的数据库编程接口JDBC来操作数据库,各数据库厂商便开发出将底层接口等效转化为JDBC接口的驱动程序,使得Java能通过JDBC统一所有数据库的API接口。

2. 导入操作

任何应用程序在编程操作时,都需要把应用程序设计好的具备实现功能的类与接口通过驱动包导入到编程项目中作为第三方库使用。

2.1 复制导入驱动包

将驱动程序包复制到作为第三方库的目录里。所有的.java文件会被编译成多个.class文件,然后将这些.class文件整理打包成一个.jar压缩包用于程序发布。

2.2 标记驱动包目录为第三方库

把驱动包所在的目录标记成第三方库。

二、JDBC编程

1. 查找资源

DataSource dataSource = new MysqlDataSource();
((MysqlDataSource)dataSource).setUrl(String_URL);

MySQL数据源凭借URL网址来找到MySQL服务器在网络上具体的资源位置。

1.1 URL地址

"jdbc:mysql://127.0.0.1:3306/test?characterEncoding=utf8&useSSL=false"

1.1.1 网址的作用

jdbc:mysql表明该网址是供jdbc程序操作mysql使用的。

1.1.2 主机IP地址

127.0.0.1是jdbc要操作的MySQL服务器所在主机的网络IP地址,当jdbc应用程序自身所在主机与MySQL服务器所在主机为同一台时,使用127.0.0.1环回IP指向自身主机,也就指向了MySQL服务器主机的位置。

1.1.3 端口号

一台主机上有诸多应用程序进行网络操作,3306是MySQL与网络对接的端口号。

1.1.4 数据库名称

确定jdbc要操作MySQL服务器中的哪个数据库。

1.1.5 访问资源参数

以键值对形式填写参数,键值对之间用&分隔。characterEncoding=utf8表示以utf8字符集进行数据库与应用程序的数据传输;useSSL=false表示数据库与应用程序之间的网络通信不加密。

2. 访问认证

((MysqlDataSource)dataSource).setUser(String_Ident);

MySQL数据源确定jdbc访问数据库的身份,root是MySQL默认自带的管理员用户。

((MysqlDataSource)dataSource).setPassword(String_Passworld);

MySQL数据源确定jdbc访问数据库的密码。

3. 连接通道

dataSource.getConnection();

——> return Connection
数据源找到并成功访问后,向jdbc建立连接通道,后续在该通道中进行请求 - 响应交互。

4. 数据传输

4.1 创建传输包
connection.prepareStatement(String_sql);

——> return PreparedStatement
在连接通道中创建传输包,将要发送的sql语句字符串存储在传输包中,传输包会对sql语句进行预处理解析、检查并打包结构化数据,在应用程序这边完成解析检查工作,减轻MySQL服务器的开销。

4.1.1 创建sql语句
4.1.1.1 直接拼接变量
String sql = "insert into student values(" + id + ", ' " + name + " ')";

直接把变量拼接进sql语句字符串,但这样可能会使数据库遭受通过sql语句输入非法内容的攻击,不安全。

4.1.1.2 用?替换变量
String sql = "insert into student values(?,?)";
connection.prepareStatement(sql);
preparedStatement.setDatatype(下标,变量);

使用占位符?先占位后规范替换的方式将变量安全地替换进sql字符串中,占位符的下标从1开始。

4.2 发送传输包
4.2.1 发送写操作的sql
preparedStatement.executeUpdate();

——> return int
传输包以写的方式发送到数据库服务器执行,返回数据库中受影响的行数。

4.2.2 发送读操作的sql
preparedStatement.executeQuery();

——> return ResultSet
传输包以读的方式发送到数据库服务器执行,返回查询结果临时表的结果集合。

4.2.2.1 遍历记录
while (resultSet.next()) {

}
resultSet.next();

——> return boolean
从临时表的第0个记录开始,往后移动光标位置进行遍历获取记录,遍历到表尾为空时返回false。

4.2.2.2 读取记录
result.getDatatype("col_name");

——> return Datatype
获取遍历所处记录的指定字段数据。

5. 回收资源

按照后获取的资源先释放的顺序回收资源。

resultSet.close();

销毁结果集合。

preparedStatement.close();

销毁传输包。

connection.close();

销毁连接通道。

文章整理自互联网,只做测试使用。发布者:Lomu,转转请注明出处:https://www.it1024doc.com/12838.html

(0)
LomuLomu
上一篇 2025 年 7 月 9 日
下一篇 2025 年 7 月 9 日

相关推荐

  • IDEA 永久激活后多久失效?2026年实测数据分享

    重要声明:本文所涉及的IntelliJ IDEA破解补丁及激活码资源均来源于网络收集,仅限个人学习研究使用,严禁用于商业用途。如有侵犯版权,请及时联系作者删除。经济条件允许的情况下,强烈建议支持正版软件! 作为JetBrains家族的明星产品,IntelliJ IDEA凭借其强大的智能代码辅助功能,已成为全球开发者首选的集成开发环境。本教程将手把手教你如何通…

    IDEA破解教程 2026 年 4 月 9 日
    4900
  • idea2026年激活可用方案

    申明:本教程 IntelliJ IDEA 破解补丁、激活码均收集于网络,请勿商用,仅供个人学习使用,如有侵权,请联系作者删除。若条件允许,希望大家购买正版 ! IDEA是 JetBrains 推出的开发编辑器,功能强大,适用于 Windows、Mac 和 Linux 系统。本文将详细介绍如何通过破解补丁实现永久激活,解锁所有高级功能。 不管你是什么版本、什么…

    IDEA破解教程 2026 年 1 月 21 日
    14800
  • 2024 DataGrip最新激活码,DataGrip永久免费激活码2025-02-14 更新

    DataGrip 2024最新激活码 以下是最新的DataGrip激活码,更新时间:2025-02-14 🔑 激活码使用说明 1️⃣ 复制下方激活码 2️⃣ 打开 DataGrip 软件 3️⃣ 在菜单栏中选择 Help -> Register 4️⃣ 选择 Activation Code 5️⃣ 粘贴激活码,点击 Activate ⚠️ 必看!必看! 🔥 …

    2025 年 2 月 14 日
    90700
  • 全新版本goland激活码免费领取和详细goland破解教程

    申明:本教程GoLand 破解补丁、激活码均收集于网络,请勿商用,仅供个人学习使用,如有侵权,请联系作者删除。若条件允许,希望大家购买正版 ! 废话不多说,先上 GoLand2025.2.1 版本破解成功的截图,如下图,可以看到已经成功破解到 2099 年辣,舒服的很! 接下来就给大家通过图文的方式分享一下如何破解最新的GoLand。 准备工作 注意:如果你…

    2026 年 1 月 20 日
    11800
  • 永久pycharm激活码免费获取与最新pycharm破解方案

    本教程适用于IDEA、PyCharm、DataGrip、Goland等,支持Jetbrains全家桶! 废话不多说,先上最新PyCharm版本破解成功的截图,如下,可以看到已经成功破解到 2099 年辣,舒服! 接下来,我就将通过图文的方式, 来详细讲解如何激活 PyCharm至 2099 年。 当然这个激活方法,同样适用于之前的旧版本! 无论你是Windo…

    PyCharm激活码 2026 年 1 月 21 日
    13300

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们

400-800-8888

在线咨询: QQ交谈

邮件:admin@example.com

工作时间:周一至周五,9:30-18:30,节假日休息

关注微信