封装JAVA数据库操作
来源:互联网 发布:手机葫芦丝模拟软件 编辑:程序博客网 时间:2024/05/18 13:07
感谢这位博主分享
import java.sql.Connection;import java.sql.DriverManager;import java.sql.ResultSet;import java.sql.ResultSetMetaData;import java.sql.SQLException;import java.sql.PreparedStatement;import java.util.ArrayList;import java.util.HashMap;import java.util.List;import java.util.Map; public class BaseDao { public final static String DRIVER = "com.microsoft.sqlserver.jdbc.SQLServerDriver"; public final static String URL = "jdbc:sqlserver://localhost:1433;databaseName=boor"; public final static String USERNAME = "sa"; public final static String PASSWORD = ""; ** * * @return 获得数据库连接 * @throws SQLException * @throws ClassNotFoundException * public Connection getConn() { Connection conn = null; try { Class.forName(DRIVER); } catch (ClassNotFoundException e) { e.printStackTrace(); } try { conn = DriverManager.getConnection(URL, USERNAME, PASSWORD); } catch (SQLException e) { e.printStackTrace(); } return conn; } ** * 关闭数据库连接 * @param conn数据库连接 * @param prsts PreparedStatement 对象 * @param rs结果集 * public void closeAll(Connection conn, PreparedStatement prsts, ResultSet rs) { if (rs != null) { try { rs.close(); } catch (SQLException e) { e.printStackTrace(); } } if (prsts != null) { try { prsts.close(); } catch (SQLException e) { e.printStackTrace(); } } if (conn != null) { try { conn.close(); } catch (SQLException e) { e.printStackTrace(); } } } ** * 执行增、删、改SQL语句 * * @param sql * sql语句 * @param param * 值集 * @param type * 值类型集 * @return 受影响的行数 * public int executeUpdate(String sql, Object[] param, int[] type) { int rows = 0; Connection conn = this.getConn(); PreparedStatement prsts = null; try { prsts = conn.prepareStatement(sql); for (int i = 1; i <= param.length; i++) { prsts.setObject(i, param[i - 1], type[i - 1]); } rows = prsts.executeUpdate(); } catch (SQLException e) { e.printStackTrace(); } finally { this.closeAll(conn, prsts, null); } return rows; } ** * 执行查询SQL语句 * * @param sql * sql语句 * @param param * 值集 * @param type * 值类型集 * @return 结果集 * public List executeQuery(String sql, Object[] param, int[] type) { ResultSet rs = null; List list = null; Connection conn = this.getConn(); PreparedStatement prsts = null; try { prsts = conn.prepareStatement(sql); for (int i = 1; i <= param.length; i++) { prsts.setObject(i, param[i - 1], type[i - 1]); } rs = prsts.executeQuery(); list = new ArrayList(); ResultSetMetaData rsm = rs.getMetaData(); Map map = null; while (rs.next()) { map = new HashMap(); for (int i = 1; i <= rsm.getColumnCount(); i++) { map.put(rsm.getColumnName(i), rs.getObject(rsm.getColumnName(i))); } list.add(map); } } catch (SQLException e) { e.printStackTrace(); }finally{ this.closeAll(conn, prsts, rs); } return list; } }
0 0
- JAVA:数据库操作封装
- JAVA:数据库操作封装
- 封装JAVA数据库操作
- JAVA:数据库操作封装
- 封装JAVA数据库操作
- 封装JAVA数据库操作
- 封装JAVA数据库操作
- 封装JAVA数据库操作-学习
- java原生数据库操作封装
- 封装Java数据库操作的类
- JAVA:数据库操作封装(1)
- JAVA:数据库操作封装(2)
- JAVA-oracle数据库封装操作连接池
- 转载【封装Java数据库操作的类】
- Java操作数据库之类的封装!...
- JAVA基础:将数据库操作封装
- 数据库操作封装--ExecuteNonQuery
- 数据库操作的封装
- Java笔记
- 阅读书这不是你的目的,你必须要列出详细目标后再进行阅读
- "查岗"软件,家人位置查询软件:极星亲友定位
- python for android : 一个单选列表的天气预报例子
- Windows 下 Apache HTTP Server 安装、配置以及与 Tomcat 的整合(附图)
- 封装JAVA数据库操作
- 存款到期OLAP多维分析(IBM powerplay)
- Erlang中出错后自动重启演示:模拟supervisor behavior
- CVPR2012-On Multiple Foreground Cosegmentation
- 告诉你什么是数据分析
- HDU 1133 Buy the Ticket
- Linux命令—文件目录
- CVPR2011-Object Cosegmentation
- SSI同步业务处理