黑马day12 DbUtils的介绍

简单介绍:

DbUtils为不喜欢hibernate框架的钟爱。它是线程安全的,不存在并发问题。

使用步骤:

1. QueryRunner runner=new QueryRunner(这里写数据源...如c3p0的数据元new ComboPooledDataSource()或者dbcp的数据元);

2.使用runner的方法假设要增删改就使用update(String sql,Object ... params)

sql:传递的sql语句

params:可变參数。为sql语句中的?所取代的參数

使用runner的方法要查询使用runner的query(String sql,ResultSetHandle handle ,Object ... params)

sql:传递的sql语句

handle :一个接口要是实现当中的handle方法

params:可变參数,为sql语句中的?所取代的參数

案例:

package com.itheima.dbutils;

import java.sql.ResultSet;
import java.sql.SQLException;

import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.ResultSetHandler;
import org.junit.Test;

import com.itheima.domain.Account;
import com.mchange.v2.c3p0.ComboPooledDataSource;

public class DbUtilsDemo1 {
	@Test
	public void add() throws SQLException{
		QueryRunner runner=new QueryRunner(new ComboPooledDataSource());
		runner.update("insert into account values(null,?,?

)", "韩玮",7000);
	}
	@Test
	public void update() throws SQLException{
		QueryRunner runner=new QueryRunner(new ComboPooledDataSource());
		runner.update("update account set money=?

where name=?

", 9000,"李卫康");
	}
	@Test
	public void delete() throws SQLException{
		QueryRunner runner=new QueryRunner(new ComboPooledDataSource());
		runner.update("delete from account where name=?

","韩玮");
	}
	@Test
	public void query() throws SQLException{
		final Account account=new Account();
		QueryRunner runner=new QueryRunner(new ComboPooledDataSource());
		runner.query("select * from account where name =?", new ResultSetHandler<Account>(){
			@Override
			public Account handle(ResultSet rs) throws SQLException {
				while(rs.next()){
					account.setId(rs.getInt("id"));
					account.setName(rs.getString("name"));
					account.setMoney(rs.getDouble("money"));
				}
				return account;
			}

		}, "李卫康");
		System.out.println(account.getMoney());
	}
}

执行结果查询数据库:

mysql> select * from account;

+----+--------+-------+

| id | name   | money |

+----+--------+-------+

|  1 | 李卫康 |  9000 |

+----+--------+-------+

1 row in set

mysql> select * from account;

+----+--------+-------+

| id | name   | money |

+----+--------+-------+

|  1 | 李卫康 | 10000 |

+----+--------+-------+

1 row in set

mysql> select * from account;

+----+--------+-------+

| id | name   | money |

+----+--------+-------+

|  1 | 李卫康 | 10000 |

|  5 | 程崇树 |  5000 |

+----+--------+-------+

时间: 2024-10-10 16:43:34

黑马day12 DbUtils的介绍的相关文章

day18(JDBC事务&连接池介绍&DBUtils工具介绍&BaseServlet作用)

day18总结 今日思维导图: 今日内容 事务 连接池 ThreadLocal BaseServlet自定义Servlet父类(只要求会用,不要求会写) DBUtils à commons-dbutils ? 事务 ? 事务的四大特性:ACID: mysql中操作事务 jdbc中操作事务 ? ? ? 事务概述 为了方便演示事务,我们需要创建一个account表: CREATE TABLE account( ????id INT PRIMARY KEY AUTO_INCREMENT, ????NA

黑马day12 数据库之元数据

声明:下面的案例在数据库为: create database day12; use day12; create table account( id int primary key auto_increment, name varchar(30), money double ); 使用的c3p0数据库 配置文件:c3p0-config.xml文件 <?xml version="1.0" encoding="UTF-8"?> <c3p0-config&

DbUtils操作数据库

1.什么是O-R  Mapping(对象-关系映射) 常用O-R Mapping映射工具      Hibernate(全自动框架)     Ibatis(半自动框架/SQL)     Commons DbUti ls(只是对JDBC简单封装) 还有JPA等之类的,这个不是特别了解,到目前为止也就接触了Hibernate和DbUtils,Hiabernate给人的不用写SQl语句,直接用配置文件去映射关系,DuUtils仍然要写sql语句,他只不过简化了crud的操作(个人看法) 2.dbuti

DBubtil的使用

1.什么是O-R Mapping(对象-关系映射) 常用O-R Mapping映射工具 Hibernate(全自动框架) Ibatis(半自动框架/SQL) Commons DbUti ls(只是对JDBC简单封装) 还有JPA等之类的,这个不是特别了解,到目前为止也就接触了Hibernate和DbUtils,Hiabernate给人的不用写SQl语句,直接用配置文件去映射关系,DuUtils仍然要写sql语句,他只不过简化了crud的操作(个人看法) 2.dbutils的介绍 commons-

Dbutils学习(介绍和入门)

一:Dbutils是什么?(当我们很难理解一个东西的官方解释的时候,就让我们记住它的作用) Dbutils:主要是封装了JDBC的代码,简化dao层的操作. 作用:帮助java程序员,开发Dao层代码的简单框架. 框架的作用:帮助程序员,提高程序的开发效率. 出生:Dbutils是由Apache公司提供. 二:为什么需要Dbutils ? 在使用Dbutils 之前,我们Dao层使用的技术是JDBC,那么分析一下JDBC的弊端: (1)数据库链接对象.sql语句操作对象,封装结果集对象,这三大对

xUtils介绍 -- DbUtils、ViewUtils、HttpUtils、BitmapUtils

转载注明出处:https://github.com/wyouflf/xUtils xUtils简单介绍 xUtils 包括了非常多有用的android工具. xUtils 支持大文件上传,更全面的http请求协议支持(10种谓词),拥有更加灵活的ORM,很多其它的事件注解支持且不受混淆影响... xUitls 最低兼容android 2.2 (api level 8) 眼下xUtils主要有四大模块: DbUtils模块: android中的orm框架,一行代码就能够进行增删改查: 支持事务,默

黑马程序员---OC基础9【Foundation框架】【NSString介绍】【NSURL读写字符串】【NSString字符串比较】【NSString前后缀检查及搜索】【NSRange使用】

------- iOS培训.Android培训.Java培训.期待与您交流! ---------- [Foundation框架] 1.Foundation框架介绍 1)Foundation框架概念 框架是由许多类.方法.函数.文档按照一定的逻辑组织起来的集合 以便使研发程序变得 更容易在OS X下的Mac操作系统中大约有80个框架为所有程序开发奠定基础的框架称为Foundation 框架 2)Foundation框架的作用 Foundation框架是Mac\iOS中其他框架的基础 Foundat

关于DButils的简单介绍

android中的orm框架,一行代码就可以进行增删改查:支持事务,默认关闭:可通过注解自定义表名,列名,外键,唯一性约束,NOT NULL约束,CHECK约束等(需要混淆的时候请注解表名和列名)等等. android有一个内置数据库Sqlite 数据库,想要实现数据库的创建要继承SQLiteOpenHelper类覆写onCreat的方法进行数据的创建:而且还要另外创建一个数据库操作类,进行对数据库的增删改查,在没有了解 DbUtils之前呢,也习惯了这种数据库的处理数据的方式,在了解熟悉了Db

黑马程序员---OC基础2【对象储存】【函数和方法的区别】【方法和对象关系】【对象作为方法参数】【NSString类介绍】

------Java培训.Android培训.iOS培训..Net培训.期待与您交流! ------- [对象储存] 1.对象的储存细节 [Car  new] new做了3件事 1)向计算机申请存储空间 2)给类中的每一个成员初始化值 3)返回新申请的空间的首地址 (1).申请的空间在内存的哪个区? new 的时候申请的空间内存的堆区(程序动态分配的内存空间) 当new内存的布局: 初始化的时候: 如果实例变量是基本数据类型,此时给初始为0, 如果是字符串类型此时初始化为null (2).实例变