时间:2021-07-01 10:21:17 帮助过:4人阅读
建一个JDBC工具类,我们就不用在每次进行数据库操作时都要进行注册驱动,获取连接对象了,减少了代码的重复性。
JDBCUtils.java
1 public class JDBCUtils { 2 //获取连接对象 3 public static Connection getConn(){ 4 Connection conn=null; 5 try { 6 //1.注册驱动 7 Class.forName("com.mysql.jdbc.Driver"); 8 //2.获取连接对象 9 String url = "jdbc:mysql://localhost:3303/java?characterEncoding=utf8"; 10 String username = "admin"; 11 String password = "123"; 12 conn=DriverManager.getConnection(url,username,password); 13 } catch (ClassNotFoundException | SQLException e) { 14 // TODO Auto-generated catch block 15 e.printStackTrace(); 16 } 17 return conn; 18 19 } 20 //增删改释放资源 21 public static void close(PreparedStatement pst,Connection conn){ 22 if(pst!=null){ 23 try { 24 pst.close(); 25 } catch (SQLException e) { 26 // TODO Auto-generated catch block 27 e.printStackTrace(); 28 } 29 } 30 if(conn!=null){ 31 try { 32 conn.close(); 33 } catch (SQLException e) { 34 // TODO Auto-generated catch block 35 e.printStackTrace(); 36 } 37 } 38 } 39 //查询释放资源、 40 public static void close(ResultSet rs, PreparedStatement pst,Connection conn){ 41 if(rs!=null){ 42 try { 43 rs.close(); 44 } catch (SQLException e) { 45 // TODO Auto-generated catch block 46 e.printStackTrace(); 47 } 48 } 49 if(pst!=null){ 50 try { 51 pst.close(); 52 } catch (SQLException e) { 53 // TODO Auto-generated catch block 54 e.printStackTrace(); 55 } 56 } 57 if(conn!=null){ 58 try { 59 conn.close(); 60 } catch (SQLException e) { 61 // TODO Auto-generated catch block 62 e.printStackTrace(); 63 } 64 } 65 } 66 }
然后在进行数据库操作:
1 public int add(String sname) throws SQLException{ 2 //获取连接对象 3 Connection conn=JDBCUtils.getConn(); 4 //获取语句执行对象 5 String sql="insert into sort(sname) values(?)"; 6 PreparedStatement pst=conn.prepareStatement(sql); 7 //执行sql语句 8 pst.setString(1, sname); 9 int row=pst.executeUpdate(); 10 //释放资源 11 JDBCUtils.close(pst, conn); 12 return row; 13 }
JDBC数据库连接
标签:name local cut lock throw static man nec main