用数据库连接池c3p0来连接数据库,用queryrunner来操作
2015-12-19 14:44
337 查看
一般在进行简单的java程序时,我们都会选择jdbc来连接数据库。但是你会发现jdbc操作数据库时的代码非常繁琐。那么有没有别的办法来替代jdbc来进行数据库的操作,且代码相当简单一点呢。答案是有的。我们要用的是queryrunner来进行操作,你会发现queryrunner将很多的都封装起来了,所以代码会变得更加简单直观。
我们先来操作数据库。在用数据库连接池时,我们要先导入c3p0-0.9.1.1.jar和mysql-connector-java-5.1.7-bin.jar,对mysql数据库进行操作 。
做到上面这几部就可以连接到数据库了。那么接下来就是用queryrunner来进行对数据库的操作。要想使用queryrunner,我们首先的导入commons-dbutils-1.2.jar。
接下来就是对数据库的操作
然后进行操作:
得到整个对象:
得到列表:
更新数据:
我们先来操作数据库。在用数据库连接池时,我们要先导入c3p0-0.9.1.1.jar和mysql-connector-java-5.1.7-bin.jar,对mysql数据库进行操作 。
JDBCUtils: private static ComboPooledDataSource dataSource = new ComboPooledDataSource();
//静态代码块自动装载连接数据库的四个参数
static { try { dataSource.setDriverClass("com.mysql.jdbc.Driver"); dataSource.setJdbcUrl(jdbc:mysql:///test); dataSource.setUser("root"); dataSource.setPassword("root"); dataSource.setMaxPoolSize(10);//设置最大的连接数 dataSource.setMinPoolSize(0);//设置最小的连接数 dataSource.setInitialPoolSize(5);//初始化连接数 dataSource.setAcquireIncrement(5);//连接数的增量 } catch (PropertyVetoException e) { // TODO Auto-generated catch block e.printStackTrace(); } }
//获得连接 4000 public static Connection getConnection() { try { return dataSource.getConnection(); } catch (SQLException e) { e.printStackTrace(); } return null; } public static ComboPooledDataSource getDataSource() { return dataSource; }
做到上面这几部就可以连接到数据库了。那么接下来就是用queryrunner来进行对数据库的操作。要想使用queryrunner,我们首先的导入commons-dbutils-1.2.jar。
接下来就是对数据库的操作
在dao层先获得连接:
static QueryRunner queryRunner = new QueryRunner(JDBCUtils.getDataSource()); static Connection conn = JDBCUtils.getConnection(); //获得连接
然后进行操作:
得到整个对象:
public static User findById(int id) { String sql = "select * from user where id=? "; Object[] params = { id }; try { return (User) queryRunner.query(conn, sql, params, new BeanHandler(User.class)); } catch (SQLException e) { e.printStackTrace(); } return null; }
得到列表:
public static List<User> list() { String sql = "select * from user "; Object[] params = { }; try { return (MailDetails) queryRunner.query(conn, sql, params, new BeanListHandler(User.class)); } catch (SQLException e) { e.printStackTrace(); } return null; }
更新数据:
public static void update(int id) { String sql = "update user set name='我就是我,是不一样的烟花' where id=?"; Object[] params = { id }; try { queryRunner.update(conn, sql, params); } catch (SQLException e) { e.printStackTrace(); } }
相关文章推荐
- MySQL中的integer 数据类型
- MySQL存储过程
- mysql中int、bigint、smallint 和 tinyint的区别与长度
- mysql load data 导出、导入 csv
- source命令执行SQL脚本文件
- MySQL创建用户及权限控制
- MySQL管理数据表
- linux下mysql添加用户
- mysql procedure
- mysql触发器
- MySQL 备份和恢复策略
- mac下安装mysql(转载)
- mysql 修改编码 Linux/Mac/Unix/通用(杜绝修改后无法启动的情况!)
- MySQL数据的导出、导入(mysql内部命令:mysqldump、mysql)
- mysql数据行转列
- Linux下修改MySQL编码的方法
- MySQL Server 日志
- MySQL 安全事宜
- MySQL 备份与恢复