MySQL数据库(Java的数据库编程:JDBC)

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
云数据库 RDS PostgreSQL,高可用系列 2核4GB
简介: MySQL数据库(Java的数据库编程:JDBC)

什么是数据库编程

数据库编程要有3个基本条件:

1、编程语言,如Java,c++/c,Python等等

2、数据库 如MySQL,Oracle,SQL Server等等

3、数据库驱动包,不同的数据库,对应不同的编程语言提供了不同的数据库驱动包,如:MySQL提供了Java的驱动包mysql-connector-java,需要基于Java操作MySQL即需要该驱动包

什么是JDBC?

JDBC,即Java Database Connectivity,java数据库连接。是一种用于执行SQL语句的Java API,它是Java中的数据库连接规范。这个API由 java.sql.*,javax.sql.* 包中的一些类和接口组成,它为Java开发人员操作数据库提供了一个标准的API,可以为多种关系数据库提供统一访问.

说白了就是用Java语言来操作数据库。原来我们操作数据库是在控制台使用SQL语句来操作数据库,JDBC是用Java语言向数据库发送SQL语句。

JDBC工作原理:

JDBC 为多种关系数据库提供了统一访问方式,作为特定厂商数据库访问API的一种高级抽象,它主要包含一些通用的接口类

JDBC中的核心类有:DriverManager、Connection、Statement,和ResultSet!

主要是通过jdbc的接口来进行的,利用接口,然后驱动数据库进行相关的操作。

JDBC的使用及相关操作:

1、首先我们要准备好数据库的驱动包,mysql-connector-java-5.1.47.jar也就是这个东西,

具体下载请访问MySQL官网:https://www.mysql.com/downloads/

2、打开IDE,创建java文件

3、创建一个Directory,命名为lib,并把下载好的jar包复制到该Directory

4、把创建好的lib右键,然后Add as library

出现这几个就是导入成功了,版本不一样可能里面的文件也会有差异。

5、创建正常的Java文件即可

JDBC开发案例:

我们在使用JDBC的时候要经过以下几个步骤:

1、先去创建 DataSource 数据源. 描述了 mysql 数据库在哪

2、和数据库建立连接

3、构造 SQL 语句

4、执行 SQL. 针对 增, 删, 改, 使用 executeUpdate 来执行,针对 查, 使用 executeQuery 来执行.

5、断开连接, 释放资源

接下来是具体的操作代码:

1. import com.mysql.jdbc.jdbc2.optional.MysqlDataSource;
2. import javax.sql.DataSource;
3. import java.sql.Connection;
4. import java.sql.PreparedStatement;
5. import java.sql.SQLException;
6. import java.util.Scanner;
7. 
8. public class JDBCInsertDemo {
9. 
10. public static void main(String[] args) throws SQLException {
11. //1、先去创建 DataSource 数据源. 描述了 mysql 数据库在哪
12.         DataSource dataSource=new MysqlDataSource();
13. 
14.        ((MysqlDataSource)dataSource).setURL("jdbc:mysql://127.0.0.1:3306/java106?characterEncoding=utf8&useSSL=false");
15.        ((MysqlDataSource)dataSource).setUser("root");
16.        ((MysqlDataSource)dataSource).setPassword("168168");
17. //2、和数据库建立连接
18.         Connection connection=dataSource.getConnection();
19. // 通过控制台, 来输入用户的信息
20.         Scanner scan=new Scanner(System.in);
21.         System.out.println("学号:");
22. int id=scan.nextInt();
23.         System.out.println("姓名:");
24.         String name=scan.next();
25. //3、构造 SQL 语句
26.         String sql="insert into student values(?,?)";
27. // jdbc 中还需要搭配一个特定的对象, 来描述这里的 sql 的情况
28.         PreparedStatement statement= connection.prepareStatement(sql);
29.         statement.setInt(1,id);
30.         statement.setString(2,name);
31.         System.out.println("sql: " + statement);
32. 
33. //4、执行 SQL. 针对 增, 删, 改, 使用 executeUpdate 来执行,针对 查, 使用 executeQuery 来执行.
34. int ret=statement.executeUpdate();
35.         System.out.println("ret="+ret);
36. //5、断开连接, 释放资源
37.         statement.close();
38.         connection.close();
39. 
40.     }
41. 
42. }
43.

我们在IDE中进行了插入一个学生的数据,现在我们看看学生表中是否出现了该数据:

是的,出现了,所以我们的插入是成功的。

首先有几个需要明确的点:

1、我们在寻找数据库的位置是用到的DataSource是一个interface,需要用一MySQLDataSource来实现这个接口。然后是需要用到强制转换为MySQLDataSource类型,使用其中的set方法来进行设置URL,User,Password,注意这些数据一定要和原来的数据库可以对应上

2、设置URl的时候要使用本地回环ip地址:也就是下面这个

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

3、建立连接的时候使用Collection接口 ,通过DataSource(数据源)对象获取连接

4、构造sql语句的时候通常使用占位符(?),其中的?所在的位置是从1开始的。使用占位符还有的好处是可读性高,而且不容易被黑客攻击。构造的sql语句需要使用Statement对象来把语句发送到数据库。

像下面这种sql语句就容易受到攻击:

String sql = "insert into student values("+ id +", '" + name + "')";

可以利用语句特点,把字符串类型的数据改为带;的数据,然后后面再跟个drop操作,你的表就直接寄了!!所以这样写很危险!!!一定要注意!

5、executeQuery() 方法执行后返回单个结果集的,通常用于select语句executeUpdate()方法返回值是一个整数,指示受影响的行数,通常用于update、insert、delete语句

6、最后别忘了释放资源!!资源占据也是非常影响效率的,其中包括有CPU,IO,硬盘,网络,带宽等等资源,要进行释放。

JDBC常用接口和类:

数据库连接Connection

Connection接口实现类由数据库提供,获取Connection对象通常有两种方式:

一种是通过DriverManager(驱动管理类)的静态方法获取

1. // 加载JDBC驱动程序
2. Class.forName("com.mysql.jdbc.Driver");
3. // 创建数据库连接
4. Connection connection = DriverManager.getConnection(url);

一种是通过DataSource(数据源)对象获取。实际应用中会使用DataSource对象

1.        DataSource dataSource=new MysqlDataSource();
2. 
3.        ((MysqlDataSource)dataSource).setURL("jdbc:mysql://127.0.0.1:3306/java106?characterEncoding=utf8&useSSL=false");
4.        ((MysqlDataSource)dataSource).setUser("root");
5.        ((MysqlDataSource)dataSource).setPassword("168168");
6. //2、和数据库建立连接
7.         Connection connection=dataSource.getConnection();

两种方式的区别:

1. DriverManager类来获取的Connection连接,是无法重复利用的,每次使用完以后释放资源

时,通过connection.close()都是关闭物理连接。

2. DataSource提供连接池的支持。连接池在初始化时将创建一定数量的数据库连接,这些连接

是可以复用的,每次使用完数据库连接,释放资源调用connection.close()都是将

Conncetion连接对象回收。

Statement对象

Statement对象主要是将SQL语句发送到数据库中。JDBC API中主要提供了三种Statement对象

1、Statement 用于执行不带参数的简单SQL语句

2、PreparedStatement 用于执行带或者不带参数的SQL语句,执行速度比Statement快,SQL会预编译在数据库系统

3、CallableStatement 用于执行数据库存储过程的调用

最常用的是PreparedStatement对象,以下对其的总结:

1、SQL预编译

2、性能比Statement高

3、参数化SQL查询

4、占位符不能使用多值

5、占位符?下标从1开始

6、阻止常见SQL注入攻击

掌握两种执行SQL的方法:

executeQuery() 方法执行后返回单个结果集的,通常用于select语句

executeUpdate()方法返回值是一个整数,指示受影响的行数,通常用于update、insert、delete语句

 

ResultSet对象  

我们在进行查询的时候,查询的结果是一个集合。

ResultSet对象它被称为结果集,它代表符合SQL语句条件的所有行,并且它通过一套getXXX方法提供了对这些行中数据的访问。

ResultSet里的数据一行一行排列,每行有多个字段,并且有一个记录指针,指针所指的数据行叫做当前数据行,我们只能来操作当前的数据行。我们如果想要取得某一条记录,就要使用ResultSet的next()方法 ,如果我们想要得到ResultSet里的所有记录,就应该使用while循环

查询案例:

1. 
2. import com.mysql.jdbc.jdbc2.optional.MysqlDataSource;
3. import javax.sql.DataSource;
4. import java.sql.Connection;
5. import java.sql.PreparedStatement;
6. import java.sql.ResultSet;
7. import java.sql.SQLException;
8. public class JDBCSelectDemo {
9. public static void main(String[] args) throws SQLException {
10. //查找数据库位置
11. DataSource dataSource = new MysqlDataSource();
12.         ((MysqlDataSource)dataSource).setURL("jdbc:mysql://127.0.0.1:3306/java106?characterEncoding=utf8&useSSL=false");
13.         ((MysqlDataSource)dataSource).setUser("root");
14.         ((MysqlDataSource)dataSource).setPassword("168168");
15. //建立连接
16. Connection connection = dataSource.getConnection();
17. //构造sql语句
18. String sql = "select * from student where id = 1";
19. PreparedStatement statement = connection.prepareStatement(sql);
20. // 结果集合
21. ResultSet resultSet = statement.executeQuery();
22. //执行SQL
23. while (resultSet.next()) {
24. // next 相当于移动一下光标, 光标指向下一行. 然后移动到结尾, 就返回 false
25. // 使用 getXX 方法获取到每一列.
26. // 这里的参数, 就是数据库表的列名.
27. int id = resultSet.getInt("id");
28. String name = resultSet.getString("name");
29.             System.out.println(id + ": " + name);
30.         }
31. // 释放资源
32.         resultSet.close();
33.         statement.close();
34.         connection.close();
35.     }
36. }

和我们在cmd中的结果一致!查询成功!

到这里就结束了,后续还会慢慢完善哈,感谢支持!


相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
相关文章
|
1月前
|
SQL Java 关系型数据库
Java连接MySQL数据库环境设置指南
请注意,在实际部署时应该避免将敏感信息(如用户名和密码)硬编码在源码文件里面;应该使用配置文件或者环境变量等更为安全可靠地方式管理这些信息。此外,在处理大量数据时考虑使用PreparedStatement而不是Statement可以提高性能并防止SQL注入攻击;同时也要注意正确处理异常情况,并且确保所有打开过得资源都被正确关闭释放掉以防止内存泄漏等问题发生。
85 13
|
3月前
|
人工智能 Java 关系型数据库
Java的时间处理与Mysql的时间查询
本文总结了Java中时间与日历的常用操作,包括时间的转换、格式化、日期加减及比较,并介绍了MySQL中按天、周、月、季度和年进行时间范围查询的方法,适用于日常开发中的时间处理需求。
|
4月前
|
人工智能 运维 关系型数据库
数据库运维:mysql 数据库迁移方法-mysqldump
本文介绍了MySQL数据库迁移的方法与技巧,重点探讨了数据量大小对迁移方式的影响。对于10GB以下的小型数据库,推荐使用mysqldump进行逻辑导出和source导入;10GB以上可考虑mydumper与myloader工具;100GB以上则建议物理迁移。文中还提供了统计数据库及表空间大小的SQL语句,并讲解了如何使用mysqldump导出存储过程、函数和数据结构。通过结合实际应用场景选择合适的工具与方法,可实现高效的数据迁移。
859 1
|
5月前
|
负载均衡 算法 关系型数据库
大数据大厂之MySQL数据库课程设计:揭秘MySQL集群架构负载均衡核心算法:从理论到Java代码实战,让你的数据库性能飙升!
本文聚焦 MySQL 集群架构中的负载均衡算法,阐述其重要性。详细介绍轮询、加权轮询、最少连接、加权最少连接、随机、源地址哈希等常用算法,分析各自优缺点及适用场景。并提供 Java 语言代码实现示例,助力直观理解。文章结构清晰,语言通俗易懂,对理解和应用负载均衡算法具有实用价值和参考价值。
大数据大厂之MySQL数据库课程设计:揭秘MySQL集群架构负载均衡核心算法:从理论到Java代码实战,让你的数据库性能飙升!
|
6月前
|
关系型数据库 MySQL 大数据
大数据新视界--大数据大厂之MySQL 数据库课程设计:MySQL 数据库 SQL 语句调优的进阶策略与实际案例(2-2)
本文延续前篇,深入探讨 MySQL 数据库 SQL 语句调优进阶策略。包括优化索引使用,介绍多种索引类型及避免索引失效等;调整数据库参数,如缓冲池、连接数和日志参数;还有分区表、垂直拆分等其他优化方法。通过实际案例分析展示调优效果。回顾与数据库课程设计相关文章,强调全面认识 MySQL 数据库重要性。为读者提供综合调优指导,确保数据库高效运行。
|
6月前
|
SQL 关系型数据库 MySQL
大数据新视界--大数据大厂之MySQL数据库课程设计:MySQL 数据库 SQL 语句调优方法详解(2-1)
本文深入介绍 MySQL 数据库 SQL 语句调优方法。涵盖分析查询执行计划,如使用 EXPLAIN 命令及理解关键指标;优化查询语句结构,包括避免子查询、减少函数使用、合理用索引列及避免 “OR”。还介绍了索引类型知识,如 B 树索引、哈希索引等。结合与 MySQL 数据库课程设计相关文章,强调 SQL 语句调优重要性。为提升数据库性能提供实用方法,适合数据库管理员和开发人员。
|
7月前
|
SQL druid Oracle
【YashanDB知识库】yasdb jdbc驱动集成druid连接池,业务(java)日志中有token IDENTIFIER start异常
客户Java日志中出现异常,影响Druid的merge SQL功能(将SQL字面量替换为绑定变量以统计性能),但不影响正常业务流程。原因是Druid在merge SQL时传入null作为dbType,导致无法解析递归查询中的`start`关键字。
|
7月前
|
SQL Java 中间件
【YashanDB知识库】yasdb jdbc驱动集成BeetISQL中间件,业务(java)报autoAssignKey failure异常
在BeetISQL 2.13.8版本中,客户使用batch insert向yashandb表插入数据并尝试获取自动生成的sequence id时,出现类型转换异常。原因是beetlsql在prepareStatement时未指定返回列,导致yashan JDBC驱动返回rowid(字符串),与Java Bean中的数字类型tid不匹配。此问题影响业务流程,使无法正确获取sequence id。解决方法包括:1) 在batchInsert时不返回自动生成的sequence id;2) 升级至BeetISQL 3,其已修正该问题。
【YashanDB知识库】yasdb jdbc驱动集成BeetISQL中间件,业务(java)报autoAssignKey failure异常
|
8月前
|
存储 Java 关系型数据库
java调用mysql存储过程
在 Java 中调用 MySQL 存储过程主要借助 JDBC(Java Database Connectivity)。其核心原理是通过 JDBC 与 MySQL 建立连接,调用存储过程并处理结果。具体步骤包括:加载 JDBC 驱动、建立数据库连接、创建 CallableStatement 对象、设置存储过程参数并执行调用。此过程实现了 Java 程序与 MySQL 数据库的高效交互。
|
8月前
|
人工智能 JavaScript 关系型数据库
【02】Java+若依+vue.js技术栈实现钱包积分管理系统项目-商业级电玩城积分系统商业项目实战-ui设计图figmaUI设计准备-figma汉化插件-mysql数据库设计-优雅草卓伊凡商业项目实战
【02】Java+若依+vue.js技术栈实现钱包积分管理系统项目-商业级电玩城积分系统商业项目实战-ui设计图figmaUI设计准备-figma汉化插件-mysql数据库设计-优雅草卓伊凡商业项目实战
279 14
【02】Java+若依+vue.js技术栈实现钱包积分管理系统项目-商业级电玩城积分系统商业项目实战-ui设计图figmaUI设计准备-figma汉化插件-mysql数据库设计-优雅草卓伊凡商业项目实战

推荐镜像

更多