原生Java操作mysql数据库过程解析

这篇文章主要介绍了原生Java操作MysqL数据库过程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

这篇文章主要介绍了原生Java操作MysqL数据库过程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

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

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

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

MysqLmysql-connector-java6.0.6

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); }

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程之家。

相关文章

HashMap是Java中最常用的集合类框架,也是Java语言中非常典型...
在EffectiveJava中的第 36条中建议 用 EnumSet 替代位字段,...
介绍 注解是JDK1.5版本开始引入的一个特性,用于对代码进行说...
介绍 LinkedList同时实现了List接口和Deque接口,也就是说它...
介绍 TreeSet和TreeMap在Java里有着相同的实现,前者仅仅是对...
HashMap为什么线程不安全 put的不安全 由于多线程对HashMap进...