• MySQL之JDBC编程


    目录

    1. 数据库编程的必备条件

    2. Java的数据库编程:JDBC 

    3. JDBC工作原理 

    4. JDBC使用 

     4.1 IDEA配置JDBC

    4.2 JDBC开发案例 

    4.3 JDBC使用步骤总结  

    5. JDBC常用接口和类 

    5.1 JDBC API 

    5.2 数据库连接Connection 

    5.3 Statement对象 

    5.4 ResultSet对象


     

    1. 数据库编程的必备条件

    • 编程语言,如 Java C C++ Python 等;
    • 数据库,如Oracle MySQL SQL Server 等;
    • 数据库驱动包:不同的数据库,对应不同的编程语言提供了不同的数据库驱动包,如:MySQL 提供了Java 的驱动包 mysql-connector-java ,要基于 Java 操作 MySQL 即需要该驱动包。同样的,要基于Java 操作 Oracle 数据库则需要 Oracle 的数据库驱动包 ojdbc  

    2. Java的数据库编程:JDBC 

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

    3. JDBC工作原理 

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

    JDBC 访问数据库层次结构:

    JDBC优势:

    1. Java语言访问数据库操作完全面向抽象接口编程
    2. 开发数据库应用不用限定在特定数据库厂商的API
    3. 程序的可移植性大大增强

    4. JDBC使用 

     4.1 IDEA配置JDBC

    首先我们要准备数据库驱动包:

    1、下载数据库驱动包

    进入https://mvnrepository.com/ 这个链接,在搜索栏输入JDBC Drivers,如图:

    点击搜索之后,会出现如下页面,然后点击箭头所指:

    进去以后,会有很多的版本,选择你所需要的版本,在这里我们选择 5.1.49 版本:

    点进去之后,出现如下界面:

    点击箭头所指方框中的 .jar 文件,进行下载,下载之后无需解压。

     找到你所下载的依赖包mysql-connector-java-5.1.49.jar:

    找到之后选中它,进行复制(直接Ctrl+C即可)。 

     2、在项目中创建文件夹lib(右击你所创建的项目,之后如图):

    点击过后,出现下图,填写你要创建的文件名(lib)即可: 

    若此处出现lib文件夹,说明创建成功。

    3、将刚才复制的依赖包mysql-connector-java-5.1.49.jar粘贴(Ctrl+V)到lib中:

    4、右击复制过来的依赖包,在列表中选择Add as Library,点击它 

    5、这时这个包就可以点开了,说明配置成功

    4.2 JDBC开发案例 

    • 创建数据源
    1. //1、创建数据源,描述了要操作的数据库在哪里
    2. DataSource dataSource = new MysqlDataSource(); //向上转型
    3. ((MysqlDataSource) dataSource).setUrl("jdbc:mysql://127.0.0.1:3306/java110?characterEncoding=utf8&useSSL=false");
    4. ((MysqlDataSource) dataSource).setUser("root");
    5. ((MysqlDataSource) dataSource).setPassword("123456");

    对于创建的数据源对象,所调用的三个方法:

    1、setUrl方法,对于URL参数有:

    2、setUser方法,里面传的是用户名,一般默认为root

    3、setPassword方法,里面传的是你要连接的数据库的密码

    •  建立数据库连接
    1. //2、和数据库服务器建立连接
    2. Connection connection = dataSource.getConnection();
    • 构造一个SQL语句,并转成语句对象 

    以插入为例: 

    1. String sql = "insert into student values(1,'小明')";
    2. //需要把String str转成语句对象
    3. PreparedStatement statement = connection.prepareStatement(sql);
    • 执行SQL语句 
    1. //4、把构造好的sql发送给服务器去执行
    2. int n = statement.executeUpdate();
    3. System.out.println("n = "+n);
    • 释放资源 
    1. //5、最后一步释放必要的资源
    2. statement.close();
    3. connection.close();

    完整代码:

    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. public class TestJDBC {
    8. public static void main(String[] args) throws SQLException {
    9. //1、创建数据源,描述了要操作的数据库在哪里
    10. DataSource dataSource = new MysqlDataSource(); //向上转型
    11. ((MysqlDataSource) dataSource).setUrl("jdbc:mysql://127.0.0.1:3306/java110?characterEncoding=utf8&useSSL=false");
    12. ((MysqlDataSource) dataSource).setUser("root");
    13. ((MysqlDataSource) dataSource).setPassword("123456");
    14. //2、和数据库服务器建立连接
    15. Connection connection = dataSource.getConnection();
    16. //3、构造一个SQL
    17. String sql = "insert into student values(1,'小明')";
    18. //需要把String str转成语句对象
    19. PreparedStatement statement = connection.prepareStatement(sql);
    20. //4、把构造好的sql发送给服务器去执行
    21. int n = statement.executeUpdate();
    22. System.out.println("n = "+n); //执行成功,会返回一个数字
    23. //5、最后一步释放必要的资源
    24. statement.close();
    25. connection.close();
    26. }
    27. }

    若想要实现由用户自己来输入要插入的值(我们这里举的例子是插入学生的学号,姓名),代码可以这样写:

    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. public class TestJDBC {
    8. public static void main(String[] args) throws SQLException {
    9. Scanner scanner = new Scanner(System.in);
    10. System.out.println("请输入姓名:");
    11. String name = scanner.nextLine();
    12. System.out.println("请输入学号:");
    13. int id = scanner.nextInt();
    14. //1、创建数据源,描述了要操作的数据库在哪里
    15. DataSource dataSource = new MysqlDataSource(); //向上转型
    16. ((MysqlDataSource) dataSource).setUrl("jdbc:mysql://127.0.0.1:3306/java110?characterEncoding=utf8&useSSL=false");
    17. ((MysqlDataSource) dataSource).setUser("root");
    18. ((MysqlDataSource) dataSource).setPassword("123456");
    19. //2、和数据库服务器建立连接
    20. Connection connection = dataSource.getConnection();
    21. //3、构造一个SQL
    22. String sql = "insert into student values(?,?)";
    23. //需要把String str转成语句对象
    24. PreparedStatement statement = connection.prepareStatement(sql);
    25. statement.setInt(1,id);
    26. statement.setString(2,name);
    27. //4、把构造好的sql发送给服务器去执行
    28. int n = statement.executeUpdate();
    29. System.out.println("n = "+n);
    30. //5、最后一步释放必要的资源
    31. statement.close();
    32. connection.close();
    33. }
    34. }

    上述代码中的 ?为占位符,下标从1开始。之后可以用PreparedStatement中的setInt方法和setString方法,将用户输入的信息与其对应。

    MySQL中的增删改操作都是类似的,这里只介绍了插入操作,删除和修改操作可以自己动手去试试。对于查询操作(select),他需要返回一个结果集,下面是执行查询操作SQL语句的代码:

    1. import com.mysql.jdbc.jdbc2.optional.MysqlDataSource;
    2. import javax.jws.soap.SOAPMessageHandlers;
    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 TestJDBCSelect {
    9. public static void main(String[] args) throws SQLException {
    10. DataSource dataSource = new MysqlDataSource();
    11. ((MysqlDataSource) dataSource).setUrl("jdbc:mysql://127.0.0.1:3306/java110?characterEncoding=utf8&useSSL=false");
    12. ((MysqlDataSource) dataSource).setUser("root");
    13. ((MysqlDataSource) dataSource).setPassword("123456");
    14. Connection connection = dataSource.getConnection();
    15. String sql = "select * from student";
    16. PreparedStatement statement = connection.prepareStatement(sql);
    17. ResultSet resultSet = statement.executeQuery();
    18. while (resultSet.next()) {
    19. int id = resultSet.getInt("id");
    20. String name = resultSet.getString("name");
    21. System.out.println("id: "+id);
    22. System.out.println("name: "+name);
    23. }
    24. //释放资源
    25. resultSet.close();
    26. statement.close();
    27. connection.close();
    28. }
    29. }

    4.3 JDBC使用步骤总结  

    1. 创建数据库连接Connection
    2. 创建操作命令Statement
    3. 使用操作命令来执行SQL
    4. 处理结果集ResultSet
    5. 释放资源

    5. JDBC常用接口和类 

    5.1 JDBC API 

    Java JDBC 编程中对数据库的操作均使用 JDK 自带的 API 统一处理,通常与特定数据库的驱动类是完全解耦的。所以掌握Java JDBC API (位于 java.sql 包下) 即可掌握 Java 数据库编程。

    5.2 数据库连接Connection 

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

    • 一种是通过DriverManager(驱动管理类)的静态方法获取:
    1. // 加载JDBC驱动程序
    2. Class.forName("com.mysql.jdbc.Driver");
    3. // 创建数据库连接
    4. Connection connection = DriverManager.getConnection(url);
    • 一种是通过DataSource(数据源)对象获取。实际应用中会使用DataSource对象。
    1. DataSource ds = new MysqlDataSource();
    2. ((MysqlDataSource) ds).setUrl("jdbc:mysql://localhost:3306/test");
    3. ((MysqlDataSource) ds).setUser("root");
    4. ((MysqlDataSource) ds).setPassword("root");
    5. Connection connection = ds.getConnection();

    上面我们JDBC开发案例用的就是数据源这种方式。 

    • 以上两种方式的区别是:
    1. DriverManager类来获取的Connection连接,是无法重复利用的,每次使用完以后释放资源
      时,通过connection.close()都是关闭物理连接。
    2. DataSource提供连接池的支持。连接池在初始化时将创建一定数量的数据库连接,这些连接
      是可以复用的,每次使用完数据库连接,释放资源调用connection.close()都是将
      Conncetion连接对象回收。

    5.3 Statement对象 

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

     

    实际开发中最常用的是 PreparedStatement 对象,以下对其的总结:

    主要掌握两种执行 SQL 的方法:
    • executeQuery() 方法执行后返回单个结果集的,通常用于select语句
    • executeUpdate()方法返回值是一个整数,指示受影响的行数,通常用于updateinsertdelete语句

    5.4 ResultSet对象

    ResultSet 对象它被称为结果集,它代表符合 SQL 语句条件的所有行,并且它通过一套 getXXX 方法提供了对这些行中数据的访问。ResultSet里的数据一行一行排列,每行有多个字段,并且有一个记录指针,指针所指的数据行叫做当前数据行,我们只能来操作当前的数据行。我们如果想要取得某一条记录,就要使用ResultSet next() 方法 ,如果我们想要得到ResultSet里的所有记录,就应该使用while循环。
    面试问答:
    1. 数据库连接有哪些方式?分别有什么区别?

     2. 数据库StatementPreparedStatement有什么区别?

     这两个问题上述内容已有答案。

  • 相关阅读:
    2265. 统计值等于子树平均值的节点数
    斐波那契数列 IV
    我用了多年的前端框架,强烈推荐!
    关于《web课程设计》网页设计 用html css做一个漂亮的网站 仿新浪微博个人主页
    电动力学专题研讨:运动电荷之间的相互作用是否满足牛顿第三定律?
    python jupyter notebook打开页面方便使用
    如何看待 Three.js / WebGL 等前端 3D 技术?
    关于maven项目中依赖无法下载的解决方案
    uni-app rich-text组件富文本图片展示不全问题
    [论文笔记]Root Mean Square Layer Normalization
  • 原文地址:https://blog.csdn.net/m0_61876562/article/details/134498016