13:55 2018/7/22
用于执行SQL语句的Java API,可以为多种关系数据库提供统一访问

---------常用API---------
|- Driver接口: 表示java驱动程序接口。所有的具体的数据库厂商要来实现此接口。
|- connect(url, properties): 连接数据库的方法。
|- DriverManager类: 驱动管理器类,用于管理所有注册的驱动程序
|-registerDriver(driver) : 注册驱动类对象
|-Connection getConnection(url,user,password); 获取连接对象
|- Connection接口: 表示java程序和数据库的连接对象。
|- Statement createStatement() : 创建Statement对象
|- PreparedStatement prepareStatement(String sql) 创建PreparedStatement对象
|- CallableStatement prepareCall(String sql) 创建CallableStatement对象
|- Statement接口: 用于执行静态的sql语句
|- int executeUpdate(String sql) : 执行静态的更新sql语句(DDL,DML)
|- ResultSet executeQuery(String sql) :执行的静态的查询sql语句(DQL)
|-PreparedStatement接口:用于执行预编译sql语句
|- int executeUpdate() : 执行预编译的更新sql语句(DDL,DML)
|- ResultSet executeQuery() : 执行预编译的查询sql语句(DQL)
|- CallableStatement接口:用于执行存储过程的sql语句(call xxx)
|- ResultSet executeQuery() : 调用存储过程的方法
|- ResultSet接口:用于封装查询出来的数据
|- boolean next() : 将光标移动到下一行
|- getXX() : 获取列的值

-----------连接---------------
【注册驱动】
Class.forName("com.mysql.jdbc.Driver");

【通过DriverManager获取连接对象】
DriverManager.getConnection(url,user,password);
JDBC的URL=协议名+子协议名+数据源名
// jdbc:mysql://localhost:3306/database
// jdbc:mysql:///database 同上简写

-----------执行DDL/DML------------
1)获取连接对象
2)获取statement对象
statement = connection.createStatement();
3)执行
statement.executeUpdate(sql); //增删改

-----------执行DQL------------
1)获取连接对象
2)获取statement对象
3)获取结果集
ResultSet result = statement.executeQuery(sql);

-----------ResultSet------------
数据结果集对象
boolean next() 默认表头,次行无数据返回false
【getXXX()】
result.getInt(1); //通过索引(从1开始)
result.getInt("id"); //通过字段名

-----------Statement------------
用于执行静态的sql语句
int executeUpdate(String sql) 执行静态的更新sql语句(DDL,DML)
ResultSet executeQuery(String sql) 执行的静态的查询sql语句(DQL)

---------PreparedStatement----------
继承Statement,执行预编译sql
【不同于Statement】
1)预编译sql语句,防止sql注入
2)可以使用sql数据库缓存区,效率高
connection.prepareStatement("insert into student_(name,gender) values(?,?)")
//设置占位符,索引从1开始
prepareStatement.setString(1, "xyg");
prepareStatement.setString(2, "h5");

------------CallableStatement--------
继承PreparedStatement,执行存储过程
CallableStatement callableStatement = connection.prepareCall(sql);
// 获取结果对象
ResultSet resultSet = callableStatement.executeQuery();

【带有返回值的存储过程】
String sql = "call getEmployById2(?,?)";
CallableStatement callableStatement = connection.prepareCall(sql);
// 设置输入参数
callableStatement.setInt(1, 2);
//设置输出参数
callableStatement.registerOutParameter(2, java.sql.Types.VARCHAR);
//执行
callableStatement.executeQuery();
//获取输出参数
//索引值与设置输出参数的位置一样
String name = callableStatement.getString(2);//getXXX专门用于获取输出参数的方法

----------获取自增长值集合--------
//1.创建satement并在参数中返回自增长列
createStatement(sql, PreparedStatement.RETURN_GENERATED_KEYS);
//执行
//2.获取自增长列集(可能多个),返回ResultSet对象
Statement.getGeneratedKeys();

-------------事务回滚------------
【手动提交】
// 一.手动提交事务,默认自动
connection.setAutoCommit(false);
【异常回滚】
connection.rollback();
【提交事务】
connection.commit();
【回滚到指定代码】
1)执行语句中设置point
savepoint = connection.setSavepoint();
2)回滚方法参数
connection.rollback(savepoint);

-----------连接池----------
【接口】连接池技术要实现的接口
javax.sql.DataSource
【实现】
1)DBCP
  DBCP是一个依赖Jakarta commons-pool对象池机制的数据库连接池.Tomcat的数据源使用的就是DBCP。
2)c3p0
  c3p0是一个开放源代码的JDBC连接池,
3)Druid

JDBC记录的更多相关文章

  1. spring jdbc 记录

    @Repository("com.example.demo.dao.impl.SmpUserDaoImpl") public class SmpUserDaoImpl implem ...

  2. Servlet开发 中使用 log4jdbc 记录 hibernate 的 SQL信息

    一.前言 使用log4jdbc在不改变原有代码的情况下,就可以收集执行的SQL文和JDBC执行情况. 平时开发使用的ibatis,hibernate,spring jdbc的sql日志信息,有一点个缺 ...

  3. MyBatis架构(转)

    本文来自http://www.bubuko.com/infodetail-549184.html 如果不太熟悉MyBatis使用的请先参见MyBatis官方文档,这对理解其架构设计和源码分析有很大好处 ...

  4. MyBatis架构设计及源代码分析系列(一):MyBatis架构

    如果不太熟悉MyBatis使用的请先参见MyBatis官方文档,这对理解其架构设计和源码分析有很大好处. 一.概述 MyBatis并不是一个完整的ORM框架,其官方首页是这么介绍自己 The MyBa ...

  5. 日志框架logj的使用

    log4j 简介 是什么? Apache的一个开源的.轻量级的.用于日志管理的框架 有什么? Log4j由三个重要的组件构成:日志信息的输出格式,日志信息的优先 级,日志信息的输出目的地. 1,日志信 ...

  6. Spring学习记录(十四)---JDBC基本操作

    先看一些定义: 在Spring JDBC模块中,所有的类可以被分到四个单独的包:1.core即核心包,它包含了JDBC的核心功能.此包内有很多重要的类,包括:JdbcTemplate类.SimpleJ ...

  7. spring jdbc获取插入记录的主键id

    在JDBC3.0规范中,当新增记录时,允许将数据库自动产生的主键值绑定到Statement或PreparedStatement中.使用Statement时,可以通过以下方法绑定主键值: int exe ...

  8. JMeter使用记录1 -- JDBC測试

    场景:使用jmeter对web应用和mysql数据库进行压力測试 JMeter是一款很强大的測试工具.能够用来測试web,数据库.从07年用过之后一直对它情有独钟,以下记录下在一个项目中对它的简单使用 ...

  9. SSM 整合 quartz JDBC方式实现job动态增删改查记录

    虽然网上有很多资料,但是都不够系统,本文记录下自己的整合过程. 1. 搭建一个SSM项目,此处略. 2. 按照quartz官方要求,建立quartz相关的数据库和表,相关sql语句如下: /* Nav ...

随机推荐

  1. java Web jsp和servlet的关系

    JSP在本质上就是SERVLET,但是两者的创建方式不一样Servlet完全是JAVA程序代码构成,擅长于流程控制和事务处理,通过Servlet来生成动态网页很不直观JSP由HTML代码和JSP标签构 ...

  2. Tarjan的LCA离线算法

    LCA(Least Common Ancestors)是指树结构中两个结点的最低的公共祖先.而LCA算法则是用于求两个结点的LCA.当只需要求一对结点的LCA时,我们很容易可以利用递归算法在O(n)的 ...

  3. C# 把一个文件夹下所有文件复制到另一个文件夹下 把一个文件夹下所有文件删除(转)

    C# 把一个文件夹下所有文件复制到另一个文件夹下   public static void CopyDirectory(string srcPath, string destPath) { try { ...

  4. AntD01 Angular2整合AntD、Angular2整合Material、利用Angular2,AntD,Material联合打造后台管理系统 ???

    待更新... 2018-5-21 13:53:52 1 环境说明 2 搭建Angular项目 详情参见 -> 点击前往 辅助技能 -> 点击前往 3 创建共享模块 ng g m share ...

  5. 新建tomcat的server服务,在左侧项目浏览处,右键空白的地方,选择new,再选择other选项

    新建tomcat的server服务,在左侧项目浏览处,右键空白的地方,选择new,再选择other选项. 在弹出的窗口中,下拉滚动条找到Server,并单击next按钮. 在弹出的窗口中,找到第一个A ...

  6. Process management of windows

    igfxem.exe进程是正常的进程.是intel家的核显驱动类的进程.核显即"核芯显卡",是指GPU部分它是与CPU建立在同一内核芯片上,两者完全融合的芯片."核芯显卡 ...

  7. Java集合框架---重构设计

    面向接口编程: 接口类型 变量 =new 实现类(); List  list=new ArrayList(); --------------------------------------- List ...

  8. JavaEE互联网轻量级框架整合开发(书籍)阅读笔记(3):常用动态代理之JDK动态代理、CGLIB动态代理

    一.动态代理的理解 动态代理的意义在于生成一个占位(又称代理对象),来代理真实对象,从而控制真实对象的访问.        先来谈谈什么是代理模式.        假设这样一个场景:你的公司是一家软件 ...

  9. LibreOJ 6000 搭配飞行员(最大流)

    题解:最基础的最大流,按照主飞行员与起点建边,副飞行员与终点建边,可以同坐的主副飞行员之间建边,值均为一,然后跑一边最大流就完美了! 代码如下: #include<queue> #incl ...

  10. [bash] 显示配色

    #/bin/bash for STYLE in 0 1 2 3 4 5 6 7; do for FG in 30 31 32 33 34 35 36 37; do for BG in 40 41 42 ...