您好,登錄后才能下訂單哦!
怎么在java中利用三層架構編寫一個電影購票系統?相信很多沒有經驗的人對此束手無策,為此本文總結了問題出現的原因和解決方法,通過這篇文章希望你能解決這個問題。
import java.lang.reflect.Field; 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.List; public class BaseDao { public static final String DRIVER = "com.mysql.jdbc.Driver"; public static final String URL = "jdbc:mysql://localhost:3306/tickets"; // 加載驅動,只需加載一次 static { try { Class.forName(DRIVER); } catch (ClassNotFoundException e) { // TODO Auto-generated catch block e.printStackTrace(); } } // 獲得連接 public Connection getConn() { Connection conn = null; try { conn = DriverManager.getConnection(URL, "root", "123456"); } catch (SQLException e) { // TODO Auto-generated catch block e.printStackTrace(); } return conn; } // 關閉所有 public void releaseAll(ResultSet rs, PreparedStatement pstmt, Connection conn) { try { if (rs != null) { rs.close(); } if (pstmt != null) { pstmt.close(); } if (conn != null) { conn.close(); } } catch (SQLException e) { // TODO Auto-generated catch block e.printStackTrace(); } } // 增刪改 封裝 public boolean operUpdate(String sql, List<Object> params) { Connection conn = null; PreparedStatement pstmt = null; int res = 0; // 獲得與數據庫的連接對象 conn = getConn(); try { pstmt = conn.prepareStatement(sql); if (params != null) { for (int i = 0; i < params.size(); i++) { pstmt.setObject(i + 1, params.get(i)); } } // 增刪改的統一方法 res = pstmt.executeUpdate(); //返回的是sql在數據庫中影響的行數 } catch (SQLException e) { // TODO Auto-generated catch block e.printStackTrace(); } finally { releaseAll(null, pstmt, conn); } return res > 0 ? true : false; } public <T> List<T> operQuery(String sql, List<Object> params, Class<T> cls) throws Exception { Connection conn = null; PreparedStatement pstmt = null; ResultSet rs = null; List<T> list = new ArrayList<T>(); conn = getConn(); try { pstmt = conn.prepareStatement(sql); if (params != null) { for (int i = 0; i < params.size(); i++) { pstmt.setObject(i + 1, params.get(i)); } } // 增刪改的統一方法 rs = pstmt.executeQuery(); ResultSetMetaData rsmd = rs.getMetaData(); while (rs.next()) { T m = cls.newInstance(); for (int i = 0; i < rsmd.getColumnCount(); i++) { String col_name = rsmd.getColumnName(i + 1); Object value = rs.getObject(col_name); Field field; field = cls.getDeclaredField(col_name); field.setAccessible(true); field.set(m, value); } list.add(m); } } catch (SQLException e) { // TODO Auto-generated catch block e.printStackTrace(); } finally { releaseAll(rs, pstmt, conn); } return list; } }
看完上述內容,你們掌握怎么在java中利用三層架構編寫一個電影購票系統的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。