Java原生操作数据库(不使用框架)

Posted zhouheblog

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Java原生操作数据库(不使用框架)相关的知识,希望对你有一定的参考价值。

1.引入数据库驱动的jar包 以通过maven引入mysql driver为例

  1.1 到http://mvnrepository.com 搜索 mysql

 

技术图片

1.2 复制所需maven配置文件到工程的 pom.xml

技术图片

<!-- https://mvnrepository.com/artifact/mysql/mysql-connector-java -->
<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
    <version>6.0.6</version>
</dependency>

2.创建数据库连接类DBUtil.java用以连接与关闭数据库

//文件名:DBUtil.java

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;

public class DBUtil 

    static String user = "root";
    static String password = "root";
    static String url = "jdbc:mysql://localhost【数据库地址】:3306【端口】/【数据库名称】?serverTimezone=UTC";

    static 
        try 
            Class.forName("com.mysql.cj.jdbc.Driver");
         catch (ClassNotFoundException e) 
            e.printStackTrace();
        
    

    public static Connection getConnection() 
        Connection conn = null;
        try 
            conn = DriverManager.getConnection(url, user, password);
         catch (SQLException e) 
            e.printStackTrace();
        
        return conn;
    

    public static void closeJDBC(ResultSet rs, Statement stmt, Connection conn) 
        if (rs != null) 
            try 
                rs.close();
             catch (SQLException e) 
                e.printStackTrace();
            
        
        if (stmt != null) 
            try 
                stmt.close();
             catch (SQLException e) 
                e.printStackTrace();
            
        
        if (conn != null) 
            try 
                conn.close();
             catch (SQLException e) 
                e.printStackTrace();
            
        
    

3.在java代码中对表进行操作

3.1 查,删,改类似

//查找table表重的 id和name
String sql = "select id,name from table";
Connection conn = DBUtil.getConnection();
PreparedStatement pstmt = null;
try 
      conn.setAutoCommit(false);
      pstmt = conn.prepareStatement(sql);
       ResultSet rs = pstmt.executeQuery();
       json = ResultSetToJson.ResultSetToJsonArray(rs);
     catch (SQLException e)
     try 
           conn.rollback();
     catch (SQLException e1)
           e1.printStackTrace();
     
finally 
    DBUtil.closeJDBC(null, pstmt, conn);

     return json;

3.1 增

int basicinfoID = 0;
String sql = "INSERT INTO tb_resume_basicinfo("
    + "basicinfo_id, realname, gender, birthday, current_loc, "
    + "resident_loc, telephone, email, job_intension, job_experience, head_shot,applicant_id) "
    +"VALUES(SEQ_ITOFFER_RESUMEBASICINFO.NEXTVAL,?,?,?,?,?,?,?,?,?,?,?)";
Connection conn = DBUtil.getConnection();
PreparedStatement pstmt = null;
        try 
            // 关闭自动提交
            conn.setAutoCommit(false);
            pstmt = conn.prepareStatement(sql);
            pstmt.setString(1, basicinfo.getRealName());
            pstmt.setString(2, basicinfo.getGender());
            pstmt.setTimestamp(3, basicinfo.getBirthday() == null ? null
                    : new Timestamp(basicinfo.getBirthday().getTime()));
            pstmt.setString(4, basicinfo.getCurrentLoc());
            pstmt.setString(5, basicinfo.getResidentLoc());
            pstmt.setString(6, basicinfo.getTelephone());
            pstmt.setString(7, basicinfo.getEmail());
            pstmt.setString(8, basicinfo.getJobIntension());
            pstmt.setString(9, basicinfo.getJobExperience());
            pstmt.setString(10, basicinfo.getHeadShot());
            pstmt.setInt(11, applicantID);
            pstmt.executeUpdate();
 catch (SQLException e) 
            try 
                // 事务回滚
                conn.rollback();
             catch (SQLException e1) 
                e1.printStackTrace();
            
            e.printStackTrace();
         finally 
            DBUtil.closeJDBC(null, pstmt, conn);
        

 

以上是关于Java原生操作数据库(不使用框架)的主要内容,如果未能解决你的问题,请参考以下文章

原生安卓开发app的框架frida安装和Python小试牛刀

框架Mybatis入门(基于原生接口的XML版本),对数据库进行简单的增删改查操作

框架Mybatis入门(基于原生接口的XML版本),对数据库进行简单的增删改查操作

Java原生的Http发送方法(不依赖框架)

Java原生的Http发送方法(不依赖框架)

Java原生的Http发送方法(不依赖框架)