JDBC连接MySQL 方法(封装方法,把增删改查操作封装在函数中)
2014-09-18 17:07
721 查看
package com.wanyifei.bean; 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; public class ConnectionDB { /** * 数据库驱动类名称 */ private static final String DRIVER = "com.mysql.jdbc.Driver"; /** * 连接字符串 */ private static final String URLSTR = "jdbc:mysql://localhost:3306/BookStore"; /** * 用户名 */ private static final String USERNAME = "root"; /** * 密码 */ private static final String USERPASSWORD = "mysql"; /** * 创建数据库连接类 */ private Connection connnection = null; private PreparedStatement preparedStatement = null; /** * 创建结果集对象 */ private ResultSet resultSet = null; static { try { // 加载数据库驱动程序 Class.forName(DRIVER); } catch (ClassNotFoundException e) { System.out.println("加载驱动错误"); System.out.println(e.getMessage()); } } /** * 建立数据库连接 * * @return */ public Connection getConnection() { try { // 获取连接 connnection = DriverManager.getConnection(URLSTR, USERNAME, USERPASSWORD); } catch (SQLException e) { System.out.println(e.getMessage()); } return connnection; } public int executeUpdate(String sql, Object[] params) { int affectedLine = 0; try { connnection = this.getConnection(); preparedStatement = connnection.prepareStatement(sql); for (int i = 0; i < params.length; i++) { preparedStatement.setObject(i + 1, params[i]); } affectedLine = preparedStatement.executeUpdate(); } catch (SQLException e) { System.out.println(e.getMessage()); } finally { closeAll(); } return affectedLine; } /** * 查询语句 * @param sql SQL语句 * @param params SQL语句 * @return List结果集 */ private ResultSet executeQueryRS(String sql, Object[] params) { try { connnection = this.getConnection(); preparedStatement = connnection.prepareStatement(sql); for (int i = 0; i < params.length; i++) { preparedStatement.setObject(i + 1, params[i]); } resultSet = preparedStatement.executeQuery(); } catch (SQLException e) { System.out.println(e.getMessage()); } return resultSet; } /** * 获取结果集,并将结果放在List中 * @param sql SQL语句 * @return List结果集 */ public List<Object> excuteQuery(String sql, Object[] params) { ResultSet rs = executeQueryRS(sql,params); ResultSetMetaData rsmd = null; int columnCount = 0; try { rsmd = rs.getMetaData(); columnCount = rsmd.getColumnCount(); } catch (SQLException e1) { System.out.println(e1.getMessage()); } List<Object> list = new ArrayList<Object>(); try { while(rs.next()) { Map<String, Object> map = new HashMap<String, Object>(); for(int i = 1; i <= columnCount; i++) { map.put(rsmd.getColumnLabel(i), rs.getObject(i)); } list.add(map); } } catch (SQLException e) { System.out.println(e.getMessage()); } finally { closeAll(); } return list; } /** * 撤销链接 */ private void closeAll() { if (resultSet != null) { try { resultSet.close(); } catch (SQLException e) { System.out.println(e.getMessage()); } } if (preparedStatement != null) { try { preparedStatement.close(); } catch (SQLException e) { System.out.println(e.getMessage()); } } if (connnection != null) { try { connnection.close(); } catch (SQLException e) { System.out.println(e.getMessage()); } } } public static void main(String[] args) { String[] params={"wanyifei"}; ConnectionDB connDB = new ConnectionDB(); List<Object> list = connDB.excuteQuery("SELECT * FROM User_Information where username= ?", params); for(int i=0;i<list.size();i++) { System.out.println(list.get(i)); } connDB.closeAll(); } }
相关文章推荐
- Python实现MySQL操作的方法小结【安装,连接,增删改查等】
- Java学习笔记——JDBC之与数据库MySQL的连接以及增删改查等操作
- 用JDBC驱动程序连接MySQL以及增删改查的操作
- 利用JDBC连接Mysql访问数据库完成增删改查操作
- JDBC----用JDBC连接Mysql并进行增删改查操作
- 【SQL】JDBC之与数据库MySQL的连接以及增删改查等操作
- 【SQL】JDBC之与数据库MySQL的连接以及增删改查等操作
- jdbc连接Mysql方法封装
- 【SQL】JDBC之与数据库MySQL的连接以及增删改查等操作
- 彻底封装JDBC操作MySQL的连接。
- Linux C语言连接MySQL 增删改查操作
- JDBC小结(附源码) 连接mysql 包含与ADO.net的操作对比及.net中的操作源码
- JDBC连接各种数据库驱动方法与连接SQLServer2000与MySQL范例
- JDBC操作连接Oracle和MySQL
- MySQL5.0中文问题及JDBC数据库连接和JSP汉字编码问题解决方法总结
- MySQL 操作函数封装
- jdbc 连接数据库、批量操作、事务(oracle、mysql)
- JAVA连接到MySql,并进行增删改查操作
- 适用,简单的数据库连接与sql操作的封装(JDBC,数据库连接池,c3p0)
- java中利用JDBC连接MySQL方法总结