07_数据库创建,添加c3p0操作所需的jar包,编写c3p0-config.xml文件,编写User.java,编写jdbcUtils.java实现操作数据库的模板工具类,UserDao编写,Dao
1
创建day14数据库,创建user.sql表:
A
创建数据库 day14
B
创建数据表
users
create
table users
(
id int
primary
keyauto_increment,
username varchar(20),
password
varchar(20)
);
2
添加依赖的jar包
|
c3p0-0.9.1.2.jar |
|
mysql-connection-java-5.0.8-bin.jar |
|
commons-beanutils-1.8.0.jar |
|
commons-logging.jar |
3
编写c3p0-config.xml
|
<?xml <c3p0-config> <default-config> <property <property <property <property <property <property </default-config> <named-config <property <property <property <property <property <property </named-config> </c3p0-config> |
4
编写User.java
|
package cn.toto.domain; public private private String private String public return } public this.id } public String getUsername() { return } public this.username } public return } public this.password } public User() { super(); } } |
5
编写jdbcUtils.java
|
package cn.toto.utils; import java.sql.Connection; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; import java.sql.Statement; import javax.sql.DataSource; import cn.toto.exception.DaoException; import com.mchange.v2.c3p0.ComboPooledDataSource; public class JdbcUtils { private static DataSource ds; static { //ds = new ComboPooledDataSource();//默认的缺省的配置 ds = new ComboPooledDataSource("toto");//配置文件中设置的内容 } //获取与指定数据的连接 public static DataSource getSource(){ return ds; } //获得与指定数据库的连接 public static Connection getConnection() throws SQLException { //从连接池返回一个连接 return ds.getConnection(); } //释放资源 public static void release(ResultSet rs,Statement stmt,Connection conn) { if(rs!=null){ try{ rs.close(); }catch(SQLException e){ e.printStackTrace(); } rs = null; } if(stmt!=null){ try{ stmt.close(); }catch(SQLException e){ e.printStackTrace(); } stmt=null; } if(conn!=null){ try{ conn.close(); }catch(SQLException e){ e.printStackTrace(); } conn = null; } } //写一个通过的增删改方法 public static boolean update(String sql,Object[] params) { Connection conn = null; PreparedStatement pstmt = null; ResultSet rs = null; try { //获得连接 conn = getConnection(); //写SQL //预编译sql pstmt = conn.prepareStatement(sql); //替换参数 int pos = 1;//设置一个脚标 //for(Object param : params) 这样写是有错误的,会有空指针异常,要写成如下的方法: for(int i=0;params!=null&&i<params.length;i++) pstmt.setObject(i+1, params[1]);//由于不知道是什么类型的,故可以用Object //发送sql int num = pstmt.executeUpdate(); //返回结果 if(num>0) return true; return false; } catch (SQLException e) { throw new DaoException(e); }finally{ release(rs,pstmt,conn); } } //实现一个通用的查询方法 public static Object query(String sql,Object[] params,ResultSetHandler handler){ Connection conn = null; PreparedStatement pstmt = null; ResultSet rs = null; try{ conn = getConnection(); //写sql //预编译sql pstmt = conn.prepareStatement(sql); //替换参数 for(int i=0;params!=null&&i<params.length;i++) pstmt.setObject(i+1, params[1]);//由于不知道是什么类型的,故可以用Object //发送sql rs = pstmt.executeQuery(); //处理结果集 /*我们在方法中需要一种功能让调用者里调用 * 在方法的内部都有一个模块不会写,有变化,需要留给调用者来处理*/ //这时我们需要用一种设计模式策略模式 TreeSet //TreeSet 实现排序,只是实现了部分功能(二叉树,还有没实现的) //(元素的比较) //让我们传入比较器实现Comparator的compare方法 /*元素的自然顺序 //向调用者要一个结果集处理器 Object result = handler.handle(rs);//调用结果处理器的handle方法,它返回的结果就是我们想要的。将结果集变成了一个对象 return result; }catch(SQLException e){ throw new DaoException(e); }finally { release(rs,pstmt,conn); } } } //写一个通过的增删改方法 public static boolean update(String sql,Object[] params) { Connection conn = null; PreparedStatement pstmt = null; ResultSet rs = null; try { //获得连接 conn = getConnection(); //写SQL //预编译sql pstmt = conn.prepareStatement(sql); //替换参数 int pos = 1;//设置一个脚标 for(Object param : params) pstmt.setObject(pos, param);//由于不知道是什么类型的,故可以用Object //发送sql int num = pstmt.executeUpdate(); //返回结果 if(num>0) return true; return false; } catch (SQLException e) { throw new DaoException(e); }finally{ release(rs,pstmt,conn); } } } |
6
编写UserDao.java
|
package cn.toto.dao; import import import import java.util.List; import cn.toto.domain.User; import import cn.toto.utils.BeanHandler; import cn.toto.utils.BeanListHandler; import cn.toto.utils.JdbcUtils; import public public List<User> getAll() { //写sql String sql = "select * from users"; //封装参数 //实现结果集处理器 List list = (List) JdbcUtils.query(sql, null, return } public User find(int String sql = "select * from users where id = ?"; //调用方法 User user = (User) JdbcUtils.query(sql, new return user; } public /*//写Sql String sql = "insert into users(username,password) values(?,?)"; //封装参数 Object[] params = new Object[2]; params[0] = user.getUsername(); params[1] = user.getPassword(); //调用新方法 boolean b = JdbcUtils.update(sql, params); return b;*/ String sql = "insert into users(username,password) values(?,?)"; boolean b = JdbcUtils.update(sql, return b; } public String sql = "update users set username=?,password=? where id=?"; return JdbcUtils.update(sql, user.getUsername() ,user.getPassword() ,user.getId() }); } public String sql = "delect from users where id=?"; return JdbcUtils.update(sql, } } |
7
编写自定义异常:DaoException.java
|
package cn.toto.exception; public private public DaoException() { } public DaoException(String message) { super(message); } public DaoException(Throwable cause) { super(cause); } public DaoException(String message, Throwable cause) super(message, cause); } } |
8
编写BeanHandler.java
在测试类中所有的类中都用到的数据可以写在@BeforeClass中。
|
package cn.toto.utils; import java.sql.ResultSet; import java.sql.ResultSetMetaData; import import org.apache.commons.beanutils.BeanUtils; import import cn.toto.exception.DaoException; public private public BeanHandler(Class clazz) { this.clazz } //将结果集的第一行数据封装到bean返回,要想返回,得加一个返回的类型,上面的代码就是获得类型的代码 public Object handle(ResultSet rs) { try { if(rs.next()){ Object bean = this.clazz.newInstance(); //获得元数据 ResultSetMetaData metaData = rs.getMetaData(); int columnCount = metaData.getColumnCount(); for(int //根据列的编号获得列名 String name = metaData.getColumnName(i); //根据列名获得这一行中这一列的值 Object value = rs.getObject(name); //使用beanutils实现属性的封装 BeanUtils.setProperty(bean, name, value); } //返回bean return bean; } return } catch (Exception e) { throw } } } |
9
编写BeanListHandler.java
|
package cn.toto.utils; import java.sql.ResultSet; import java.sql.ResultSetMetaData; import import java.util.ArrayList; import java.util.List; import org.apache.commons.beanutils.BeanUtils; import cn.toto.exception.DaoException; //它的功能是将数据封装到bean,然后再将数据封装到List集合中 public private public BeanListHandler(Class clazz){ this.clazz } //实现接口,要实现接口中的方法中。 //将结果集的每一行封装到bean,将bean加入一个List返回 public Object handle(ResultSet rs) { try{ List list = new while(rs.next()){ Object bean = this.clazz.newInstance(); //知道列名 //获得结果集的元数据 ResultSetMetaData metaData = rs.getMetaData(); //获得列的数量 int columnCount = metaData.getColumnCount(); for(int //获得类名 String columnName = metaData.getColumnName(i); //获得列对应的值 Object value = rs.getObject(columnName); BeanUtils.setProperty(bean, columnName, value); } //将bean存入List集合 list.add(bean); } return list; }catch(Exception e){ throw } } } |
10
编写ResultSetHandler.java
|
package cn.toto.utils; import java.sql.ResultSet; public Object handle(ResultSet rs); } |
12
编写UserDaoTest.java
|
package junit.test; import java.util.List; import org.junit.Test; import cn.toto.dao.UserDao; import cn.toto.domain.User; public private UserDao @Test public User user = new User(); user.setUsername("zhangsan"); user.setPassword("11111111"); boolean b = System.out.println(b); } @Test public List all = dao.getAll(); System.out.println(all); } @Test public User user = dao.find(0); System.out.println(user); } } |
07_数据库创建,添加c3p0操作所需的jar包,编写c3p0-config.xml文件,编写User.java,编写jdbcUtils.java实现操作数据库的模板工具类,UserDao编写,Dao的更多相关文章
- idea 为模块添加Tomcat依赖 解决: Intelij IDEA 创建WEB项目时没有Servlet的jar包
解决: Intelij IDEA 创建WEB项目时没有Servlet的jar包 今天创建SpringMVC项目时 用到HttpServletRequest时, 发现项目中根本没有Servlet这个包, ...
- Maven创建工程项目如何下载所需要的jar包
转自:http://hi.baidu.com/hotthought/item/57ce101556d0ba0de75c36c5 Maven包的下载路径: http://maven.apache.org ...
- json-lib-2.4-jdk15.jar所需全部JAR包.rar java jsoup解析开彩网api接口json数据实例
json-lib-2.4-jdk15.jar所需全部JAR包.rar java jsoup解析开彩网api接口json数据实例 json-lib-2.4-jdk15.jar所需全部JAR包.rar ...
- 02_c3p0之c3p0-config.xml配置案例,操作c3p0的jdbcUtil工具类的编写
c3p0也是一个开源jdbc连接池,我们熟悉的Hibernate和Spring框架使用的都是该数据源. 这里获得数据源使用的方法是:ComboPooledDataSource 它提供的构造方法有 ...
- web工程 所需是jar包总结
commons-beanutils-1.8.3.jar : BeanUtils主要提供了对于JavaBean进行各种操作,需要Commons -Collections包和Commons -loggin ...
- SpringBoot+Maven多模块项目(创建、依赖、打包可执行jar包部署测试)完整流程
一,创建Maven多模块项目先建立外层父工程 File →new →project 选择Spring Initializr Next下一步到以下页面 工程结构如下 ...
- 二.创建maven工程及下载需要的jar包
1.使用Eclipse的Maven插件来创建一简单的Maven项目 步骤:打开新建项目对话框,选择Maven Project(File->New->Object->Maven-> ...
- SSH整合所需的jar包
Spring3.1+Hibernate3+Struts2的最新整合所需要的jar包 Spring的基本jar包: 1.org.springframework.web-3.1.4.RELEASE.jar ...
- maven添加本地非repository中的jar包
1.今天在使用maven编译打包一个web应用的时候,碰到一个问题: 项目在开发是引入了依赖jar包,放在了WEB-INF/lib目录下,并通过buildpath中将web libariary导入. ...
随机推荐
- 计蒜客NOIP模拟赛D2T2 直线的交点
伦伦刚刚在高中学习了解析几何,学会了计算两条直线的交点.这天,老师给她布置了一道作业.在平面上有 nnn 条直线,他们之间有若干交点.给定一对平板(两条平行的直线),问这有多少对直线,他们的交点在这一 ...
- ●CodeChef Sereja and Game
题链: https://www.codechef.com/problems/SEAGM题解: 概率dp,博弈论 详细题解:http://www.cnblogs.com/candy99/p/650434 ...
- ●BZOJ 2820 YY的GCD
题链: http://www.lydsy.com/JudgeOnline/problem.php?id=2820 题解: 莫比乌斯反演 先看看这个题:HDU 1695 GCD(本题简化版) HDU 1 ...
- [bzoj1566][NOI2009]管道取珠
来自FallDream的博客,未经允许,请勿转载,谢谢. n<=500 神题...... 发现这个平方可以看作两个序列相同的对数 然后就可以表示状态了. f[i][j][k]表示两个序列各选了 ...
- bzoj3675[Apio2014]序列分割 斜率优化dp
3675: [Apio2014]序列分割 Time Limit: 40 Sec Memory Limit: 128 MBSubmit: 3508 Solved: 1402[Submit][Stat ...
- Codeforces Round#402(Div.1)掉分记+题解
哎,今天第一次打div1 感觉头脑很不清醒... 看到第一题就蒙了,想了好久,怎么乱dp,倒过来插之类的...突然发现不就是一道sb二分吗.....sb二分看了二十分钟........ 然后第二题看了 ...
- Unix系统的文件目录项的内容是什么,这样处理的好处是什么?
(Unix系统采用树型目录结构,而且目录中带有交叉勾链.每个目录表称为一个目录文件.一个目录文件是由目录项组成的.) 每个目录项包含16个字节,一个辅存磁盘块(512B)包含32个目录项.在目录项中, ...
- JAVA的Date类与Calendar类(常用方法)
http://blog.csdn.net/xiaopihai86/article/details/50827945 1.用Java.util.Calender来实现 Calendar cal ...
- centos7.2中文乱码解决办法
centos7.2 中文乱码解决办法 1.查看安装中文包: 查看系统是否安装中文语言包 (列出所有可用的公共语言环境的名称,包含有zh_CN) # locale -a |grep "zh_C ...
- [ Java学习基础 ] Java的抽象类与接口
一.抽象类 1. 抽象类 Java语言提供了两种类:一种是具体类:另一种是抽象子类. 2. 抽象类概念: 在面向对象的概念中,所有的对象都是通过类来描绘的,但是反过来,并不是所有的类都是用来描绘对象的 ...