JDBC(Java Data Base Connectivity) java数据连接
可以为多种数据库,提供统一访问,它由一组用java语言编写的类和接口组成,也是java访问数据库的规范。
 
mysql数据库驱动程序jar包
选 connector/j/ 下载
 
导入mysql数据库驱动程序jar包
file->project structure->modules->添加 jars or directories ->选择目标.jar
 
增删改 executeUpdate
String driverName = "com.mysql.jdbc.Driver";
//数据库地址 jdbc:mysql://主机IP:端口号/数据库名字
String url = "jdbc:mysql://localhost:3306/david2018_db";
String user = "root";
String password = "1234";
try {
//1.注册驱动
Class.forName(driverName);
 
//2.连接数据库
Connection conn = DriverManager.getConnection(url, user, password);
 
//3.获得执行对象
Statement stat = conn.createStatement();
 
//4.执行insert语句
String sql = "insert into users (uname,uaddress,tel) values ('baidawei','changpingqu','18755488125')";
int result = stat.executeUpdate(sql);
 
System.out.println("插入"+result+"条数据");
 
//5.释放资源
stat.close();
conn.close();
 
} catch (ClassNotFoundException e) {
e.printStackTrace();
} catch (SQLException e) {
e.printStackTrace();
}
 
查询数据 executeQuery
String driverName = "com.mysql.jdbc.Driver";
//数据库地址 jdbc:mysql://主机IP:端口号/数据库名字
String url = "jdbc:mysql://localhost:3306/david2018_db";
String user = "root";
String password = "1234";
try {
//1.注册驱动
Class.forName(driverName);
 
//2.连接数据库
Connection conn = DriverManager.getConnection(url, user, password);
 
//3.获得执行对象
Statement stat = conn.createStatement();
 
//4.执行select语句
String sql = "select * from users";
ResultSet rs = stat.executeQuery(sql);
while(rs.next()){
System.out.print(rs.getInt("uid"));
System.out.print(rs.getString("uname"));
System.out.println(rs.getString("uaddress"));
}
 
//5.释放资源
rs.close();
stat.close();
conn.close();
 
} catch (ClassNotFoundException e) {
e.printStackTrace();
} catch (SQLException e) {
e.printStackTrace();
}
}
 
PrepareStatement预编译 防 or 1=1 sql注入
String driverName = "com.mysql.jdbc.Driver";
//数据库地址 jdbc:mysql://主机IP:端口号/数据库名字
String url = "jdbc:mysql://localhost:3306/david2018_db";
String user = "root";
String password = "1234";
try {
//1.注册驱动
Class.forName(driverName);
 
//2.连接数据库
Connection conn = DriverManager.getConnection(url, user, password);
 
//3.获得执行对象
Statement stat = conn.createStatement();
 
//4.执行select语句
//String id = "5";
//String sql = "select * from users where uid > " + id;
String sql = "select * from users where uid > ?";
PreparedStatement pst = conn.prepareStatement(sql);
pst.setObject(1,5); //从1开始
ResultSet rs = pst.executeQuery(); //这里是pst的executeQuery()无参方法
while(rs.next()){
System.out.print(rs.getInt("uid"));
System.out.print(rs.getString("uname"));
System.out.println(rs.getString("uaddress"));
}
 
//5.释放资源
rs.close();
stat.close();
conn.close();
 
} catch (ClassNotFoundException e) {
e.printStackTrace();
} catch (SQLException e) {
e.printStackTrace();
}
 
修改操作
//4.执行update语句
String sql = "update users set uname = ? where uid = ?";
PreparedStatement pst = conn.prepareStatement(sql);
pst.setObject(1,"david");
pst.setObject(2,7);
 
int result = pst.executeUpdate();
System.out.println(result);
 
封装JDBCUtils工具类
import java.sql.*;
 
public class JDBCUtils {
private JDBCUtils(){}
 
private static Connection con ;
static{
try{
String driverName = "com.mysql.jdbc.Driver";
//数据库地址 jdbc:mysql://主机IP:端口号/数据库名字
String url = "jdbc:mysql://localhost:3306/david2018_db";
String user = "root";
String password = "1234";
//1.注册驱动
Class.forName(driverName);
 
//2.连接数据库
con = DriverManager.getConnection(url, user, password);
 
}catch(Exception ex){
throw new RuntimeException(ex+"数据库连接失败");
}
}
 
public static Connection getConnection(){
return con;
}
 
public static void close(Connection con,Statement stat){
 
if(stat!=null){
try{
stat.close();
}catch(SQLException ex){}
}
 
if(con!=null){
try{
con.close();
}catch(SQLException ex){}
}
 
}
 
public static void close(Connection con,Statement stat , ResultSet rs){
if(rs!=null){
try{
rs.close();
}catch(SQLException ex){}
}
 
if(stat!=null){
try{
stat.close();
}catch(SQLException ex){}
}
 
if(con!=null){
try{
con.close();
}catch(SQLException ex){}
}
 
}
}
 
测试工具类
public static void main(String[] args) {
Connection con = JDBCUtils.getConnection();
PreparedStatement pst = null;
try {
pst = con.prepareStatement("select * from users");
 
ResultSet rs = pst.executeQuery();
List<users> list = new ArrayList<users>();
while (rs.next()) {
users u = new users();
u.uid = rs.getInt("uid");
u.uname = rs.getString("uname");
u.uaddress = rs.getString("uaddress");
u.utel=rs.getString("tel");
list.add(u);
}
for(users u : list){
System.out.println(u.toString());
}
JDBCUtils.close(con, pst, rs);
} catch (SQLException e) {
e.printStackTrace();
}
}
 
配置文件
src目录下新建database.properties文件
driverName=com.mysql.jdbc.Driver
url=jdbc:mysql://localhost:3306/david2018_db
user=root
password=1234
 
加载配置文件
//类加载器
InputStream in = 当前类名.class.getClassLoader().getResourceAsStream("database.properties");
 
Properties pro = new Properties();
pro.load(in);
 
String driverName = pro.getProperty("driverName");
String url = pro.getProperty("url");
String user = pro.getProperty("user");
String password = pro.getProperty("password");
 
连接mysql方法
import java.io.InputStream;
import java.sql.Connection;
import java.sql.DriverManager;
import java.util.Properties;
 
public class JDBCUtilsConfig {
private static Connection con;
 
static {
InputStream in = JDBCUtilsConfig.class.getClassLoader().getResourceAsStream("database.properties");
 
Properties pro = new Properties();
try {
pro.load(in);
 
String driverName = pro.getProperty("driverName");
String url = pro.getProperty("url");
String user = pro.getProperty("user");
String password = pro.getProperty("password");
 
Class.forName(driverName);
con = DriverManager.getConnection(url, user, password);
} catch (Exception e) {
e.printStackTrace();
}
}
 
public static Connection getCon() {
return con;
}
}
 
DBUtils
简化JDBC开发
下载DBUtils jar包
command+; 导入jar包
 
QueryRunner.update 增删改
新增:
Connection con = JDBCUtilsConfig.getCon();
QueryRunner qr = new QueryRunner();
String sql = "insert into users (uname,uaddress,tel) values (?,?,?)";
Object[] params = {"davidddd","bj","15156156156156"};
int result = qr.update(con,sql,params);
System.out.println("添加"+result+"条数据");
DbUtils.closeQuietly(con);
 
修改:
Connection con = JDBCUtilsConfig.getCon();
QueryRunner qr = new QueryRunner();
String sql = "update users set uname = ?,uaddress = ? where uid = ?";
Object[] params = {"david1","sh",8};
int result = qr.update(con,sql,params);
System.out.println("修改"+result+"条数据");
DbUtils.closeQuietly(con);
 
删除:
Connection con = JDBCUtilsConfig.getCon();
QueryRunner qr = new QueryRunner();
String sql = "delete from users where uid = ?";
int result = qr.update(con,sql,8);
System.out.println("删除"+result+"条数据");
DbUtils.closeQuietly(con);
 
QueryRunner.query 查询
查询:
ArrayHandler 返回第一行Object[]
ArrayListHandler 返回List<Object[]>
Connection con = JDBCUtilsConfig.getCon();
QueryRunner qr = new QueryRunner();
String sql = "select * from users where uid > ?";
List<Object[]> result = qr.query(con,sql,new ArrayListHandler(),1);
for(Object[] obj : result){
for(Object o : obj){
System.out.println(o);
}
}
DbUtils.closeQuietly(con);
 
BeanHandler 返回第一行JavaBean对象
BeanListHandler 返回List JavaBean对象
Connection con = JDBCUtilsConfig.getCon();
QueryRunner qr = new QueryRunner();
String sql = "select * from users where uid > ?";
List<users> result = qr.query(con,sql,new BeanListHandler<users>(users.class),1);
for(users u : result){
System.out.println(u);
}
DbUtils.closeQuietly(con);
 
ColumnListHandler 返回List Object对象 按列查询
ScalarHandler 返回第一条数据 适合count
Connection con = JDBCUtilsConfig.getCon();
QueryRunner qr = new QueryRunner();
String sql = "select count(*) from users where uid > ?";
Long count = qr.query(con,sql,new ScalarHandler<Long>(),1);
System.out.println(count);
DbUtils.closeQuietly(con);
 
MapHandler 返回第一个Map对象 key value
MapListHandler 返回ListMap对象
Connection con = JDBCUtilsConfig.getCon();
QueryRunner qr = new QueryRunner();
String sql = "select * from users where uid > ?";
List<Map<String, Object>> result = qr.query(con,sql,new MapListHandler(),1);
for(Map<String,Object> map : result){
System.out.println(map.get("uid"));
}
DbUtils.closeQuietly(con);
 
连接池
共享Connection,避免频繁创建连接、释放连接操作。
用连接池来管理Connection,可以重复使用COnnection,不用我们自己创建Connection,
通过连接池来创建Connection对象,关闭也不会真正的关闭连接,而是吧Connection归还给它,连接池就可以再利用这个对象了。
DBCP
数据库连接池是apache上的一个Java连接池项目,DBCP所依赖的jar包
dbcp.jar poll.jar logging.jar 这三个jar包
导入jar包 command+;
 
BasicDataSource dataSource = new BasicDataSource();
dataSource.setDriverClassName("com.mysql.jdbc.Driver");
dataSource.setUrl("jdbc:mysql://localhost:3306/david2018_db");
dataSource.setUsername("root");
dataSource.setPassword("1234");
dataSource.setInitialSize(10);//初始化连接数
dataSource.setMaxIdle(5); //最大空闲
dataSource.setMinIdle(1); //最小空闲
 
Connection con = dataSource.getConnection();
QueryRunner qr = new QueryRunner(dataSource);
String Sql = "select * from users";
List<users> list = qr.query(Sql,new BeanListHandler<users>(users.class));
for(users u : list){
System.out.println(u.uname);
}

JDBC、DBUtils的更多相关文章

  1. 29_Java_数据库_第29天(JDBC、DBUtils)_讲义

    今日内容介绍 1.JDBC 2.DBUtils 01JDBC概念和数据库驱动程序 * A: JDBC概念和数据库驱动程序 * a: JDBC概述 * JDBC(Java Data Base Conne ...

  2. 数据库(JDBC、DBUtils)

     JDBC(Java DataBase Connection) 今日内容介绍 u SQL语句查询 u JDBC 第1章 JDBC 1.1 JDBC概述 JDBC(Java Data Base Conn ...

  3. java基础(29):JDBC、DBUtils

    1. JDBC 1.1 JDBC概述 JDBC(Java Data Base Connectivity,java数据库连接)是一种用于执行SQL语句的Java API,可以为多种关系数据库提供统一访问 ...

  4. JDBC及DBUtils

    1.JDBC2.DBUtils ###01JDBC概念和数据库驱动程序 * A: JDBC概念和数据库驱动程序 * a: JDBC概述 * JDBC(Java Data Base Connectivi ...

  5. pache—DBUtils框架简介、DbUtils类、QueryRunner类 、ResultSetHandler接口

    Apache—DBUtils框架简介.DbUtils类.QueryRunner类 .ResultSetHandler接口 commons-dbutils 是 Apache 组织提供的一个开源 JDBC ...

  6. java语言体系的技术简介之JSP、Servlet、JDBC、JavaBean(Application)

    转自:https://zhangkunnan.iteye.com/blog/2040462 前言 Java语言 Java语言体系比较庞大,包括多个模块.从WEB项目应用角度讲有JSP.Servlet. ...

  7. jdbc框架-dbutils的简单使用

    jdbc框架-dbutils的简单使用 dbutils:是apache组织的一个工具类,jdbc的框架,更方便我们使用 使用步骤: 1.导入jar包(commons-dbutils-1.4.jar) ...

  8. Hibernate和JDBC、EJB比较

    参考:http://m.blog.csdn.net/article/details?id=7228061 一.Hibernate是JDBC的轻量级的对象封装,它是一个独立的对象持久层框架,和App S ...

  9. 面试问到:JDBC、hibernate、ibati

    一.JDBC.Connection(连接) 优点:运行高效.快捷. 缺点:代码多.异常多.不支持跨平台. 二.ibatis 1.根据jdbc的基本建立连接. 2.通过anntation+xml.jav ...

随机推荐

  1. 高性能C++网络库libtnet实践:comet单机百万连接挂载测试

    最近在用go语言做一个挂载大量长连接的推送服务器,虽然已经完成,但是内存占用情况让我不怎么满意,于是考虑使用libtnet来重新实现一个.后续我会使用comet来表明推送服务器. 对于comet来说, ...

  2. Git版本控制:Git查阅、撤销文件修改和撤销文件追踪

    http://blog.csdn.net/pipisorry/article/details/47867097 查看文件的修改历史 git log --pretty=oneline 文件名 # 显示修 ...

  3. 集群通信组件tribes之集群的平行通信

    前面的集群成员维护服务为我们提供了集群内所有成员的地址端口等信息,可以通过MembershipService可以轻易从节点本地的成员列表获取集群所有的成员信息,有了这些成员信息后就可以使用可靠的TCP ...

  4. MySQL的一些常用的SQL语句整理

    安装MySQL有两种的方式,一种是解压版本,但是需要配置环境变量,相对而言比较麻烦.所以我们一般采取第二种方式,那就是到MySQL的官网上下载安装版.这样就会省去很多麻烦,在这里我就不再详细的介绍具体 ...

  5. 【一天一道LeetCode】#39. Combination Sum

    一天一道LeetCode系列 (一)题目 Given a set of candidate numbers (C) and a target number (T), find all unique c ...

  6. STL算法设计理念 - 谓词,一元谓词demo

    谓词: 一元函数对象:函数参数1个: 二元函数对象:函数参数2个: 一元谓词 函数参数1个,函数返回值是bool类型,可以作为一个判断式 谓词可以使一个仿函数,也可以是一个回调函数. demo 一元谓 ...

  7. startService与bindService的区别

    转自:http://www.devdiv.com/thread-52226-1-1.html Service的生命周期方法比Activity少一些,只有onCreate, onStart, onDes ...

  8. mysql进阶(十五) mysql批量删除大量数据

    mysql批量删除大量数据 假设有一个表(syslogs)有1000万条记录,需要在业务不停止的情况下删除其中statusid=1的所有记录,差不多有600万条, 直接执行 DELETE FROM s ...

  9. android 之ViewStub

    在开发应用程序的时候,经常会遇到这样的情况,会在运行时动态根据条件来决定显示哪个View或某个布局.那么最通常的想法就是把可能用到的View都写在上面,先把它们的可见性都设为View.GONE,然后在 ...

  10. adb shell后出现error解决方案

    解决办法: 解决办法: 1.adb kill-server 2.adb start-server 3.adb remount 4.adb shell 一般情况下都可以在此启动adb相关