java學習筆記——使用JDBC,對資料庫進行增刪改查(方案二)

來源:互聯網
上載者:User

工具類BaseDao.java

package com.accp.jdbc;import java.sql.Connection;import java.sql.DriverManager;import java.sql.PreparedStatement;import java.sql.ResultSet;import java.sql.ResultSetMetaData;import java.sql.SQLException;import java.util.ArrayList;import java.util.HashMap;import java.util.List;import java.util.Map;import org.apache.log4j.Logger;public class BaseDao {// 使用log4j記錄日誌private static Logger logger = Logger.getLogger(BaseDao.class);// 串連驅動private static final String DRIVER = "com.microsoft.sqlserver.jdbc.SQLServerDriver";// 串連路徑private static final String URL = "jdbc:sqlserver://localhost:1433;databaseName=test";// 使用者名稱private static final String USERNAME = "sa";// 密碼private static final String PASSWORD = "sa";//靜態代碼塊static {try {// 載入驅動Class.forName(DRIVER);} catch (ClassNotFoundException e) {e.printStackTrace();logger.error("載入驅動失敗", e);}}/* * 擷取資料庫連接 */public Connection getConnection() {Connection conn = null;logger.debug("開始串連資料庫");try{//與資料庫建立串連conn=DriverManager.getConnection(URL, USERNAME, PASSWORD);}catch(SQLException e){e.printStackTrace();logger.error("資料庫連接失敗!",e);}logger.debug("資料庫連接成功");return conn;}/* * 關閉資料庫連接,注意關閉的順序 */public void close(ResultSet rs, PreparedStatement ps, Connection conn) {//注意:最後開啟的最先關閉if(rs!=null){try{rs.close();rs=null;}catch(SQLException e){e.printStackTrace();logger.error("關閉ResultSet失敗",e);}}if(ps!=null){try{ps.close();ps=null;}catch(SQLException e){e.printStackTrace();logger.error("關閉PreparedStatement失敗",e);}}if(conn!=null){try{conn.close();conn=null;}catch(SQLException e){e.printStackTrace();logger.error("關閉Connection失敗",e);}}}/* * 查詢多個對象的方法 *  * sql: 要執行的sql語句 * obj:可變參數列表 */public List<Map<String,Object>> queryList(String sql,Object... obj){List<Map<String,Object>> data=new ArrayList<Map<String,Object>>();Connection conn=getConnection(); //獲得串連PreparedStatement ps=null;ResultSet rs=null;try{//建立PreparedStatement對象ps=conn.prepareStatement(sql);//為查詢語句設定參數setParameter(ps, obj);//獲得ResultSet結果集rs=ps.executeQuery();//獲得結果集資訊ResultSetMetaData rsmd=rs.getMetaData();// 獲得列的總數int columnCount=rsmd.getColumnCount();Map<String,Object> row=null;// 遍曆結果集,根據資訊封裝成Mapwhile(rs.next()){row=new HashMap<String, Object>();for(int i=0;i<columnCount;i++){String columnLabel=rsmd.getColumnLabel(i+1);row.put(columnLabel, rs.getObject(columnLabel));}data.add(row);}}catch(SQLException e){e.printStackTrace();logger.error("資料庫操作異常",e);}finally{//關閉串連close(rs,ps,conn);logger.debug("釋放資源成功");}return data;}/* * 查詢一個對象的方法 *  * sql: 要執行的sql語句 * obj:可變參數列表 */public Map<String,Object> query(String sql,Object... obj){Map<String,Object> data=null;Connection conn=getConnection(); //獲得串連PreparedStatement ps=null;ResultSet rs=null;try{//建立PreparedStatement對象ps=conn.prepareStatement(sql);//為查詢語句設定參數setParameter(ps, obj);//獲得ResultSet結果集rs=ps.executeQuery();//獲得結果集資訊ResultSetMetaData rsmd=rs.getMetaData();// 獲得列的總數int columnCount=rsmd.getColumnCount();// 遍曆結果集,根據資訊封裝成Mapwhile(rs.next()){data=new HashMap<String, Object>();for(int i=0;i<columnCount;i++){String columnLabel=rsmd.getColumnLabel(i+1);data.put(columnLabel, rs.getObject(columnLabel));}}}catch(SQLException e){e.printStackTrace();logger.error("資料庫操作異常",e);}finally{//關閉串連close(rs,ps,conn);logger.debug("釋放資源成功");}return data;}/* * 增加、修改、刪除,的方法 *  * obj: 可變參數列表 */public int update(String sql,Object...obj ){Connection conn=getConnection(); //獲得串連PreparedStatement ps=null;int rows=0;try{//建立PreparedStatement對象ps=conn.prepareStatement(sql);//為查詢語句設定參數setParameter(ps, obj);//獲得受影響的行數rows=ps.executeUpdate();}catch(SQLException e){e.printStackTrace();logger.error("資料庫操作異常",e);}finally{//關閉串連close(null,ps,conn);logger.debug("釋放資源成功");}return rows;}/* * 為先行編譯對象設定參數 */public void setParameter(PreparedStatement ps,Object... obj)throws SQLException {if(obj!=null && obj.length>0){//迴圈設定參數for (int i = 0; i < obj.length; i++) {ps.setObject(i+1, obj[i]);}}}}

操作類,進行增刪改查 UserDao.java

package com.accp.jdbc;import java.sql.Connection;import java.sql.PreparedStatement;import java.sql.ResultSet;import java.sql.ResultSetMetaData;import java.sql.SQLException;import java.sql.Statement;import java.util.List;import java.util.Map;import com.accp.entity.User;public class UserDao extends BaseDao {public static void main(String[] args) {UserDao user=new UserDao();/*      //查詢id<20的資料user.queryUser();//查詢單條資料user.queryUserById(10);//更新資料User u=new User();u.setId(2);u.setName("張龍");u.setAge(22);System.out.println("更新"+user.updateUser(u)+"條資料");//刪除資料System.out.println("刪除"+user.deleteUser(15)+"條資料");//插入資料User u1=new User();u1.setName("張三");u1.setAge(18);user.insertUser(u1);  */}//查詢多條資訊public void queryUser(){List<Map<String,Object>> dataUser=queryList("select * from users where id<20");//遍曆結果集for(Map<String,Object> u:dataUser){System.out.println(u);}}//查詢單條資料public void queryUserById(int id){System.out.println(query("select * from users where id=?",id));}//更新資料public int updateUser(User user){String sql="update users set name=?,age=? where id=?";return update(sql, user.getName(),user.getAge(),user.getId());}//刪除資料public int deleteUser(int id){String sql="delete from users where id=?";return update(sql,id);}//插入資料,並返回自動成長的的主索引值public void insertUser(User user){Connection conn=getConnection(); //獲得串連PreparedStatement ps=null;ResultSet rs=null;String sql="insert into users values(?,?)";try{// 建立能返回自動產生的主鍵的值的先行編譯對象ps=conn.prepareStatement(sql, Statement.RETURN_GENERATED_KEYS);ps.setString(1,user.getName());ps.setInt(2, user.getAge());int rows=ps.executeUpdate();// 獲得自動成長的的主索引值rs=ps.getGeneratedKeys();rs.next();//獲得idint id=rs.getInt(1);System.out.println("成功添加:"+rows+"條資料,id是:"+id);}catch(SQLException e){e.printStackTrace();}finally{close(rs,ps,conn);}}}

插入測試資料 InsertTest.java

package com.accp.jdbc;import java.sql.Connection;import java.sql.PreparedStatement;import java.sql.SQLException;public class InsertTest extends BaseDao  {public static void main(String[] args) {InsertTest user=new InsertTest();user.insertUser();}public void insertUser() {String sql = "insert into users values(?,?)";Connection conn = getConnection();PreparedStatement ps = null;try {// 禁止自動認可事務conn.setAutoCommit(false);// 建立能返回自動產生的主鍵的值的先行編譯對象ps = conn.prepareStatement(sql);//開始時間的毫秒數Long start=System.currentTimeMillis();for (int i = 0; i < 10000; i++) {ps.setString(1, i+"");ps.setInt(2, 22);ps.addBatch();// 添加到批處理命令中}ps.executeBatch();// 執行批處理conn.commit();// 提交事務//結束時間的毫秒數Long stop=System.currentTimeMillis();//得到總耗時Long ms=stop-start; System.out.println("插入一萬記錄耗時:"+ms+"毫秒");} catch (SQLException e) {e.printStackTrace();//取消事務try{conn.rollback();}catch(SQLException ee){ee.printStackTrace();}} finally {//開啟自動認可事務try {conn.setAutoCommit(true);} catch (SQLException e) {e.printStackTrace();}close(null, ps, conn);}}}

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.