JDBC终章- 使用 DBUtils实现增删查改- C3P0Utils数据源/QueryRunner runner连接数据源并执行sql
JDBC终章- 使用 DBUtils实现增删查改
1.数据库结构
Create Table CREATE TABLE `user` (
`id` int(3) NOT NULL AUTO_INCREMENT,
`name` varchar(20) NOT NULL,
`password` varchar(20) NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8
2.工程结构
SRC目录下的 c3p0-config.xml
<?xml version="1.0" encoding="UTF-8"?> <c3p0-config> <named-config name="szs"> <property name="user">root</property>
<property name="password">123456</property>
<property name="jdbcUrl">jdbc:mysql://localhost:3306/jdbc</property>
<property name="driverClass">com.mysql.jdbc.Driver</property> <property name="acquireIncrement">2</property>
<property name="initialPoolSize">5</property>
<property name="minPoolSize">5</property>
<property name="maxPoolSize">10</property> <property name="maxStatements">20</property>
<property name="maxStatementsPerConnection">5</property> </named-config>
</c3p0-config>
具体的JAR 包如下:
3.创建C3P0Utils 数据源
package day_23; import com.mchange.v2.c3p0.ComboPooledDataSource;
import org.junit.Test; import javax.sql.DataSource;
import java.sql.SQLException; public class C3P0Utils {
private static DataSource ds;
static {
ds=new ComboPooledDataSource("szs"); //这里因为配置文件中没有default,故需要自定义的
}
public static DataSource getDataSource() throws SQLException {
return ds;
}
}
4.创建DBUtilsDao类,实现增删查改
package day_23;
import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.handlers.BeanListHandler; import java.sql.SQLException;
import java.util.List; //创建DBUtilsDao类
public class DBUtilsDao {
//查询所有,返回List集合
public List findAll() throws SQLException{
//创建QueryRunner 对象
QueryRunner runner=new QueryRunner(C3P0Utils.getDataSource()) ;
//写SQL语句
String sql="select * from user";
//调用方法
List list=(List)runner.query(sql,new BeanListHandler(User.class));
return list;
}
//查询单个对象的id,返回List集合中的第一个对象
public User find(int id) throws SQLException{
//创建QueryRunner 对象
QueryRunner runner=new QueryRunner(C3P0Utils.getDataSource()) ;
//写SQL语句
String sql="select * from user where id= ?";
//调用方法
List list=(List)runner.query(sql,new BeanListHandler(User.class),id);
return (User)list.get(0);
}
//添加用户的操作
public Boolean insert(User user) throws SQLException{
//创建QueryRunner 对象
QueryRunner runner=new QueryRunner(C3P0Utils.getDataSource()) ;
//写SQL语句
String sql="insert into user (name,password) values (?,?)";
//调用方法
int num=runner.update(sql,new Object[]{user.getName(),user.getPassword()});
if(num>0){
System.out.println("添加用户成功!");
return true;
}
else
return false;
}
//修改用户的操作
public Boolean update(User user) throws SQLException{
//创建QueryRunner 对象
QueryRunner runner=new QueryRunner(C3P0Utils.getDataSource()) ;
//写SQL语句
String sql="update user set name=?,password=? where id=?";
//调用方法
int num=runner.update(sql,new Object[]{user.getName(),user.getPassword(),user.getId()});
if(num>0){
System.out.println("更新用户成功!");
find(user.getId()).toString();
return true;
}
else
return false;
}
//删除用户的操作 ,根据用户的id
public Boolean delete(int id) throws SQLException{
//创建QueryRunner 对象
QueryRunner runner=new QueryRunner(C3P0Utils.getDataSource()) ;
//写SQL语句
String sql="delete from user where id =?";
//调用方法
int num=runner.update(sql,id);
if(num>0){
System.out.println("删除用户成功!");
return true;
}
else
return false;
} }
5.测试DBUtilsDao类的 增(insert)删查改,四个功能
package day_23; import java.sql.SQLException;
import java.util.List; //测试增(insert)删查改,四个功能
public class DBUtilsDaoTest {
private static DBUtilsDao dao=new DBUtilsDao(); public static void testInsert() throws SQLException{
User user=new User();
user.setId(1);
user.setName("赵六");
user.setPassword("666666");
boolean b=dao.insert(user);
System.out.println(b);
}
public static void testDelete() throws SQLException{
System.out.println(dao.delete(1));
}
public static void testfind() throws SQLException {
System.out.println(dao.find(2));
}
public static void testfindAll() throws SQLException{
List<User> users= dao.findAll();
for(int i=0;i<users.size();i++)
System.out.println(users.get(i));
}
public static void testUpdate() throws SQLException{
User user=new User();
user.setId(5);
user.setName("赵六66");
user.setPassword("666666");
boolean b=dao.insert(user);
System.out.println(b);
}
public static void main(String[] args) throws SQLException {
testInsert();
testDelete();
testUpdate();
testfind();
testfindAll(); }
}
6.最终控制台的结果展示
添加用户成功!
true
false
添加用户成功!
true
User{id=2, name='李四', password='123456'}
User{id=2, name='李四', password='123456'}
User{id=3, name='王五', password='123456'}
User{id=4, name='赵六', password='666666'}
User{id=5, name='赵六', password='666666'}
User{id=6, name='赵六66', password='666666'}
User{id=7, name='赵六', password='666666'}
User{id=8, name='赵六66', password='666666'}
JDBC终章- 使用 DBUtils实现增删查改- C3P0Utils数据源/QueryRunner runner连接数据源并执行sql的更多相关文章
- JDBC课程4--使用PreparedStatement进行增删查改--封装进JDBCTools的功能中;模拟SQL注入 ; sql的date()传入参数值格式!
主要内容: /*SQL 的date()需要传入参数值: preparedStatement().setDate(new java.util.Date().getTime()); 熟悉了使用Prepar ...
- DButils实现增删查改
获取数据库连接 static Connection con=JdbcUtils.MyUtils();//这个连接类静态获取要自己定义 插入 public static void insert() th ...
- 利用dbutils工具实现数据的增删查改操作(dbutis入门)
一.前期准备 1.安装数据库(如:mysql5.5) 2.安装Eclipse(如:3.4) 3.下载数据库驱动包 4.下载dbutis工具包 5.在Eclipse创建名为 dbutils 的工程并在工 ...
- [课本]JDBC课程6--使用JDBC的DAO模块化--完成数据库的增删查改_工具类JDBCTools四个(Preparedstatement)功能模块的敲定版
(课本P273-任务九) /**DAO: Data Access Object * 为什么用: 实现功能的模块化,更有利于代码的维护和升级 * 是什么: 访问数据信息的类,包含对数据的CRUD(cre ...
- 在Eclipse上实现简单的JDBC增删查改操作
在Javaweb的学习里,学到了如何完成简单的增删查改操作,在这里撰写一篇文章以便自己整理回忆. 首先要建立一些包和导入一些文件.建一些类.具体框架如图 编写Product类 public clas ...
- jdbc的实例应用:增删查改实现
//在jdbc中进行增删查改 //查看所有 public static void findAll() { String url = "jdbc:mysql://localhost:3306/ ...
- 2015.8.2 jdbc实现商品类的增删查改
在惠普济宁基地进行了两周sql和java的学习,学到很多东西 刚才实现了用jdbc访问数据库对数据库进行操作,是用eclipse写的,过几天移植到NetBeans上,个人还是比较习惯看图形化界面 前几 ...
- JDBC+Servlet+jsp(增删查改)
先在mysql新增数据库和表先,把下面的几句代码复制去到mysql运行就可以创建成功了! 创建数据库 create database jdbc01 character set utf8 collat ...
- hibernate基础增删查改简单实例
hibernate 基础理论知识网上很多,可以百度和google.这里不做多的介绍,以一个User表来开展例子 建一个web-project 我这里用了junit单元测试环境来进行增删查改的测试,别的 ...
随机推荐
- [转帖]nginx sendfile tcp_nopush tcp_nodelay参数解释
nginx sendfile tcp_nopush tcp_nodelay参数解释 2013-06-25 13:59:40 zmj_88888888 阅读数 20425 文章标签: nginxtcp_ ...
- Java多线程系列--AQS之 LockSupport
concurrent包是基于AQS (AbstractQueuedSynchronizer)框架的,AQS(JAVA CAS原理.unsafe.AQS)框架借助于两个类: Unsafe(提供CAS操作 ...
- jwt单点登入
主要有以下三步: 项目一开始我先封装了一个JWTHelper工具包(GitHub下载),主要提供了生成JWT.解析JWT以及校验JWT的方法,其他还有一些加密相关操作.工具包写好后我将打包上传到私 ...
- Web Services使用SOAP Header
在Web Services方法进行通信使用SOAP遵循标准的SOAP格式,该格式的一部分是在XML文档中编码的数据.XML文档包含一个Envelope根元素(由必需的Body元素和可选的Header元 ...
- java 读取文件流
搬运自速学堂:https://www.sxt.cn/Java_jQuery_in_action/ten-iqtechnology.html JAVA中IO流体系: 四大IO抽象类 ·InputStre ...
- ELK搜索条件
1.要搜索一个确切的字符串,即精确搜索,需要使用双引号引起来:path:”/app/logs/nginx/access.log” 2.如果不带引号,将会匹配每个单词:uid token 3.模糊搜索: ...
- C# 卡控时间输入
int hour = (int.Parse(DateTime.Now.Hour.ToString())) * 60; int minute = int.Parse(DateTime.No ...
- 每周分享五个 PyCharm 使用技巧(三)
文章首发于 微信公众号:Python编程时光 PyCharm 是大多数 Python 开发者的首选 IDE,每天我们都在上面敲着熟悉的代码,写出一个又一个奇妙的功能. 一个每天都在使用的工具,如果能掌 ...
- centos7 GNOME 安装微信客户端
写在前边 最近新装了一个 centos7 GNOME 系统,用了很久了 win,突然转换 linux 桌面版,觉得焕然一新,给搬砖生活增添了一份新意 ~ 先看一下效果图: 怎么弄呢? 下载最新版本 t ...
- 使用 pykafka 进行消费
kafka连接脚本 环境:python3,用到的模块有 pykafka,kazoo # coding=utf-8 import pykafka class KafkaReaderThread(obje ...