JDBC学习笔记

本文介绍了使用JDBC进行数据库操作的基本流程,包括加载数据库驱动、执行SQL语句、处理结果及断开连接释放资源。重点讲解了Statement与PreparedStatement的区别及应用场景。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

JDBC学习笔记-JDBC详细的操作流程
  • 博客分类:
  • jdbc

所有的JDBC应用程序都具有下面的基本流程:
  1、加载数据库驱动并建立到数据库的连接。
  2、执行SQL语句。
  3、处理结果。
  4、从数据库断开连接释放资源。

下面我们就来仔细看一看每一个步骤:

其实按照上面所说每个阶段都可得单独拿出来写成一个独立的类方法文件。共别的应用来调用。

1、加载数据库驱动并建立到数据库的连接:

Html代码
  1. String driverName="com.mysql.jdbc.Driver"
  2. String connectiionString="jdbc:mysql://10.5.110.239:3306/test?"+"user=root&password=chen&characterEncoding=utf-8"; 
  3. Connection connection=null
  4. try { 
  5.     Class.forName(driverName);//这里是所谓的数据库驱动的加载 
  6.     connection=(Connection) DriverManager.getConnection(connectiionString);//这里就是建立数据库连接 
  7.     System.out.println("数据库连接成功"); 
  8. } catch (ClassNotFoundException e) { 
  9.     // TODO Auto-generated catch block 
  10.     e.printStackTrace(); 
  11. return connection; 
2、执行SQL语句:

在执行sql语句的时候,这里常见的有两种类型的语句对象:

Statement:它提供了直接在数据库中执行SQL语句的方法。对于那些只执行一次的查询、删除或者一种固定的sql语句来说已经足够了。

Html代码
  1. Statement statement=(Statement) dUtil.getConnection().createStatement(); 
  2.              
  3.             String sql="delete from diary where title="+"'"+title+"'"; 
  4.              
  5.             int count=statement.executeUpdate(sql); 
  6.              
  7.             System.out.println("删除成功"); 

Preparedstatement:这种语句对象用于那些需要执行多次,每次仅仅是数据取值不同的SQL语句,它还提供了一些方法,以便指出语句所使用的输入参数。

Html代码
  1. String sql="insert into diary(title,content,authorname,time) values(?,?,?,now())"
  2.         try { 
  3.             PreparedStatement preparedStatement=(PreparedStatement) dUtil.getConnection().prepareStatement(sql); 
  4.             String title=diary.getTitle(); 
  5.             String content=diary.getContent(); 
  6.             String authorname=diary.getAuthorName(); 
  7.             preparedStatement.setString(1, title); 
  8.             preparedStatement.setString(2, content); 
  9.             preparedStatement.setString(3, authorname); 
3、处理结果:

Html代码
  1. ResultSet resultSet=statement.executeQuery(sql); 
  2.             while (resultSet.next()) { 
  3.                 Diary diary=new Diary(); 
  4.                 diary.setAuthorName(resultSet.getString("authorname")); 
  5.                 diary.setContent(resultSet.getString("content")); 
  6.                 diary.setTitle(resultSet.getString("title")); 
  7.                 diary.setId(resultSet.getInt("id")); 
  8.                 Date time=resultSet.getDate("time"); 
此处,应该知道的是:Statement执行sql语句的方法:insert、Update、delete语句是使用了Statement的executeUpdate方法执行的,返回结果是插入、更新、删除的个数。而select语句执行较为特别是使用了Statement的executeQuery方法执行的。返回的结果存放在resultset结果集中,我们可以调用next()方法来移到结果集中的下一条记录。结果集由行和列组成,各列数据可以通过相应数据库类型的一系列get方法(如getString,getInt,getDate等等)来取得。

4、从数据库断开连接释放资源:

在结果集、语句和连接对象用完以后,我们必须正确地关闭它们。连接对象、结果集对象以及所有的语句对象都有close()方法,通过调用这个方法,我们可以确保正确释放与特定数据库系统相关的所有资源。

Html代码
  1. public static void closeConnection(ResultSet resultSet,PreparedStatement preparedStatement, Connection connection) throws SQLException { 
  2.          
  3.         if (resultSet!=null) resultSet.close(); 
  4.         if (preparedStatement!=null) preparedStatement.close(); 
  5.         if(connection!=null&&connection.isClosed()==false) connection.close(); 
  6.         System.out.println("数据库关闭"); 
  7.      
  8.     } 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值