溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么在java中利用三層架構編寫一個電影購票系統(tǒng)

發(fā)布時間:2021-03-25 16:26:16 來源:億速云 閱讀:175 作者:Leah 欄目:編程語言

怎么在java中利用三層架構編寫一個電影購票系統(tǒng)?相信很多沒有經驗的人對此束手無策,為此本文總結了問題出現的原因和解決方法,通過這篇文章希望你能解決這個問題。

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));
 
 }
 
 }
 // 增刪改的統(tǒng)一方法
 
 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));
 
 }
 
 }
 // 增刪改的統(tǒng)一方法
 
 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中利用三層架構編寫一個電影購票系統(tǒng)的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注億速云行業(yè)資訊頻道,感謝各位的閱讀!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI