JdbcUtil类:

  1. package com.xiaohui.jdbc.util;
  2. import java.sql.Connection;
  3. import java.sql.PreparedStatement;
  4. import java.sql.ResultSet;
  5. import java.sql.SQLException;
  6. import javax.sql.DataSource;
  7. import com.mchange.v2.c3p0.ComboPooledDataSource;
  8. public final class JdbcUtil {
  9. private static ComboPooledDataSource dataSource;
  10. static {
  11. dataSource = new ComboPooledDataSource();
  12. }
  13. // 取得链接
  14. public static Connection getMySqlConnection() throws SQLException {
  15. return dataSource.getConnection();
  16. }
  17. //
  18. public static DataSource getDataSource(){
  19. return dataSource;
  20. }
  21. // 关闭链接
  22. public static void close(Connection conn) throws SQLException {
  23. if (conn != null) {
  24. try {
  25. conn.close();
  26. } catch (SQLException e) {
  27. e.printStackTrace();
  28. throw e;
  29. }
  30. }
  31. }
  32. public static void close(PreparedStatement pstate) throws SQLException {
  33. if(pstate!=null){
  34. pstate.close();
  35. }
  36. }
  37. public static void close(ResultSet rs) throws SQLException {
  38. if(rs!=null){
  39. rs.close();
  40. }
  41. }
  42. }

c3p0-config.xml

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <c3p0-config>
  3. <default-config>
  4. <property name="driverClass">com.mysql.jdbc.Driver</property>
  5. <property name="user">root</property>
  6. <property name="password">root</property>
  7. <property name="jdbcUrl">jdbc:mysql://127.0.0.1:3306/mysql4</property>
  8. </default-config>
  9. </c3p0-config>

分页的一个dao:

  1. package com.xiaohui.cusSys.dao;
  2. import java.sql.SQLException;
  3. import java.util.List;
  4. import org.apache.commons.dbutils.QueryRunner;
  5. import org.apache.commons.dbutils.handlers.BeanHandler;
  6. import org.apache.commons.dbutils.handlers.BeanListHandler;
  7. import org.apache.commons.dbutils.handlers.ScalarHandler;
  8. import com.xiaohui.cusSys.domain.Customer;
  9. import com.xiaohui.cusSys.util.JdbcUtil;
  10. public class Dao {
  11. private QueryRunner qr = new QueryRunner(JdbcUtil.getDataSource());
  12. // 根据id返回 Customer 对象
  13. public Customer getCustomerById(int id) throws SQLException {
  14. String sql = "select * from customer where id = ?";
  15. Customer cus = (Customer) qr.query(sql,
  16. new BeanHandler(Customer.class), id);
  17. return cus;
  18. }
  19. // 分页返回
  20. public List<Customer> getFyList(int start, int size) throws SQLException {
  21. List<Customer> list = null;
  22. String sql = "select * from customer limit ?,?";
  23. list = qr.query(sql, new BeanListHandler(Customer.class), new Object[] {
  24. start, size });
  25. return list;
  26. }
  27. // 返回记录的总数目
  28. public int getAllRecordsCount() throws SQLException {
  29. String sql = "select count(*) from customer";
  30. Long temp = qr.query(sql, new ScalarHandler());
  31. return temp.intValue();
  32. }
  33. // 根据ID删除指定的记录
  34. public void deleteRecordById(int id) throws SQLException {
  35. String sql = "delete from customer where id = ?";
  36. qr.update(sql, id);
  37. }
  38. // 根据id更新记录信息
  39. public void updateRecordById(Customer newCus) throws SQLException {
  40. String sql = "update customer set name= ?,address= ?,tel= ?,mail= ?,birthday= ? where id= ?";
  41. qr.update(
  42. sql,
  43. new Object[] { newCus.getName(), newCus.getAddress(),
  44. newCus.getTel(), newCus.getMail(),
  45. newCus.getBirthday(), newCus.getId() });
  46. }
  47. // 添加记录
  48. public void addRecord(Customer newCus) throws SQLException {
  49. String sql = "insert into customer(name,address,tel,mail,birthday) values(?,?,?,?,?)";
  50. qr.update(sql, new Object[] { newCus.getName(), newCus.getAddress(),
  51. newCus.getTel(), newCus.getMail(),
  52. // //将java.util.Date 转换为 java.sql.Date
  53. // new java.sql.Date( newCus.getBirthday().getTime())
  54. newCus.getBirthday() });
  55. }
  56. }

jar文件:c3p0-0.9.1.2.jar (关键)  mysql-connector-java-5.1.22-bin.jar(关键) 在dao中 使用到commons-dbutils-1.5.jar

 

JDBC链接数据库版本三,使用C3P0,使用jar文件两个的更多相关文章

  1. jdbc链接数据库的三种方式

    /** * jdbc连接数据库 * @author APPle * */ public class Demo1 { //连接数据库的URL private String url = "jdb ...

  2. 4、原生jdbc链接数据库常用资源名

    原生jdbc链接数据库要素:#MySql:String url="jdbc:mysql://localhost:3306/数据库名";String name="root& ...

  3. jdbc链接数据库,获取表名,字段名和数据

    import java.sql.Connection; import java.sql.DatabaseMetaData; import java.sql.DriverManager; import  ...

  4. 分享非常有用的Java程序 (关键代码) (三)---创建ZIP和JAR文件

    原文:分享非常有用的Java程序 (关键代码) (三)---创建ZIP和JAR文件 import java.util.zip.*; import java.io.*; public class Zip ...

  5. JDBC操作数据库的三种方式比较

    JDBC(java Database Connectivity)java数据库连接,是一种用于执行上sql语句的javaAPI,可以为多种关系型数据库提供统一访问接口.我们项目中经常用到的MySQL. ...

  6. JDBC链接数据库步骤

    java中定义链接数据库的标准:JDBC 1.导包:不同数据库有不同的jdbc驱动包,而且jdbc驱动包和数据库版本必须对应 2.测试 3.写代码 try { 1.//加载JDBC驱动    Clas ...

  7. jdbc链接数据库

    JDBC简介 JDBC全称为:Java Data Base Connectivity (java数据库连接),可以为多种数据库提供填统一的访问.JDBC是sun开发的一套数据库访问编程接口,是一种SQ ...

  8. Java JDBC链接数据库

     1.注册驱动Class.forname("com.mysql.jdbc.Driver");//这是连接mysql数据库的驱动2.获取数据库连接java.sql.Connectio ...

  9. 1019 JDBC链接数据库进行修删改查

    package com.liu.test01; import java.sql.Statement; import java.sql.Connection; import java.sql.Drive ...

随机推荐

  1. ios学习总结(2) -- UIButton的使用

    原文地址 UIButton的类是一个UIControl子类,它实现了在触摸屏上的按钮.触摸一个按钮拦截事件和动作消息发送到目标对象时,它的挖掘.设定的目标和行动方法都继承自UIControl.这个类提 ...

  2. Fresco 源码分析(三) Fresco服务端处理(1) ImagePipeline为何物

    4.3 服务端的处理 备注: 因为是分析,而不是设计,所以很多知识我们类似于插叙的方式叙述,就是用到了哪个知识点,我们再提及相关的知识点,如果分析到了最后,我想想是不是应该将这个架构按照设计的方式,重 ...

  3. svn利用钩子post-commit自动更新到线上测试服务器(测试中未验证)

    创建一个新的版本库: [root@centos03 svn]# pwd /home/svn [root@centos03 svn]# svnadmin create webtest [root@cen ...

  4. oracle 10g 学习之多表查询、分组函数(6)

    笛卡尔集 l  笛卡尔集会在下面条件下产生: 省略连接条件 连接条件无效 所有表中的所有行互相连接 l  为了避免笛卡尔集, 可以在 WHERE 加入有效的连接条件. 自连接 select m.las ...

  5. 【HTML5】Application Cache应用程序缓存

    HTML5 引入了应用程序缓存,这意味着 web 应用可进行缓存,并可在没有因特网连接时进行访问. 应用程序缓存为应用带来三个优势: 离线浏览 - 用户可在应用离线时使用它们 速度 - 已缓存资源加载 ...

  6. servlet中cookie的使用

    ---恢复内容开始--- Cookie是存储在客户端计算机上的文本文件,并保留了它们的各种信息跟踪的目的. Java Servlet透明支持HTTP Cookie. 涉及标识返回用户有三个步骤: 服务 ...

  7. Python实践:模块自动重载

    一.概述 二.思路 三.实现 四.测试 1.开启自动重载(终端1) 2.修改模块(终端2) 3.查看实时输出(终端1) 五.参考源码 一.概述 开发Web程序时,通常会采用本地服务器进行调试,但如果代 ...

  8. node工具--express

    //使用supervisor  Connect是基于HTTP米快创建的:Express则是基于Connect上创建的: 绝大多数web服务器和浏览器之间的任务是通过url和method完成的,两者的组 ...

  9. Google地图接口API之Google地图 API 参考手册(七)

    Google 地图API 参考手册 地图 构造函数/对象 描述 Map() 在指定的 HTML 容器中创建新的地图,该容器通常是一个DIV元素. 叠加层 构造函数/对象 描述 Marker 创建一个标 ...

  10. 手把手教你 用 wpf 制作metro ProgressRing (Windows8 等待动画)

    效果图: 还在羡慕metro的ProgressRing吗? wpf 也可以拥有 首先说下思路, 一共6个点围绕一直圆转,所以需要使用rotation动画 并且一直转下去. 那么下面的问题就好解决了. ...