java 使用JDBC连接数据库步骤及示例

一、工具类:其中dataUrl、userName、passpord分别为数据库的连接串、用户名、密码。

package com.test.utils;

import com.neusoft.ehrss.base.si.person.documentPlat.config.DocumentConfiguration;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;

import java.sql.*;

/**
 * 数据库工具类
 *
 * @author 
 * @date 2021/10/25 11:25
 */
@Component
public class JDBCUtil {

    @Autowired
    private DocumentConfiguration documentConfiguration;

    /**
     * 获取数据库连接
     *
     * @return
     */
    public Connection getConnection() {
        Connection conn = null;
        try {
            Class.forName("oracle.jdbc.driver.OracleDriver").newInstance();
            conn = DriverManager.getConnection(documentConfiguration.getDataUrl(), documentConfiguration.getUsername(), documentConfiguration.getPassword());
            //是否自动提交
            conn.setAutoCommit(false);
        } catch (Exception e) {
            e.printStackTrace();
            System.out.println("==数据库连接失败:" + e.getMessage());
        }
        return conn;
    }

    /**
     * 释放资源
     *
     * @param conn
     * @param pstmt
     */
    public void release(Connection conn, PreparedStatement pstmt) {
        if (pstmt != null) {
            try {
                pstmt.close();
            } catch (SQLException e) {
                e.printStackTrace();
            }
        }

        if (conn != null) {
            try {
                conn.close();
            } catch (SQLException e) {
                e.printStackTrace();
            }
        }
    }

}

二、代码示例

1、创建数据库连接:

  //获取数据库连接
  Connection conn = documentServiceImpl.jDBCUtil.getConnection();

2、创建一个Statement

//创建Statement
 PreparedStatement pstmt = null;

要执行SQL语句,必须获得java.sql.Statement实例,分以下三种类型:

  • 执行静态的SQL语句,通常通过Statement实例实现。
  • 执行动态的SQL语句,通常通过PreparedStatement实例实现。
  • 执行数据库存储过程,通常通过CallableStatement实例实现。

 对应的实现方式如下:

  1. Statement stmt = con.createStatement() ; 
  2. PreparedStatement pstmt = con.prepareStatement(sql) ;
  3. CallableStatement cstmt =   con.prepareCall("{CALL demoSp(? , ?)}") ;   

3、执行sql语句

提供了三种执行SQL语句的方法:

  1. ResultSet executeQuery(String sqlString)执行查询数据库的SQL语句,返回一个结果集(ResultSet)对象
  2.  int executeUpdate(String sqlString):用于执行INSERT、UPDATE或DELETE语句以及SQL DDL语句,如:CREATE TABLE和DROP TABLE等
  3. execute(sqlString):用于执行返回多个结果集、多个更新计数或二者组合的语句

4、处理结果

两种情况:

  1. 执行查询返回的结果是一个ResultSet对象。
  2. 执行更新返回的是本次操作影响到的记录数。 

使用结果集对象的访问方法获取数据:

  1. while(rs.next()){   
  2.          String name = rs.getString("name") ;   
  3.     String pass = rs.getString(1) ; // 此方法比较高效   
  4.     }   

5、关闭数据库连接

  1. 关闭记录集(如果有的话)
  2. 关闭声明
  3. 关闭连接 

 代码片段:

Connection conn = documentServiceImpl.jDBCUtil.getConnection();
PreparedStatement pstmt = null;
String sql = "SELECT * FROM DUAL"
pstmt = conn.prepareStatement(sql);
pstmt.setString(1, "测试");
pstmt.setLong(2, 123L);
pstmt.setDate(3, new java.sql.Date(new java.util.Date().getTime()));
int row = pstmt.executeUpdate();

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值