博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[03-01]JDBC基础
阅读量:6555 次
发布时间:2019-06-24

本文共 1380 字,大约阅读时间需要 4 分钟。

JDBC是什么?

  1.java Database Connectivity:java访问数据库的解决方案;

  2.用相同的方式访问不同的数据库,以实现与具体数据库无关的java操作界面;

  3.JDBC定义一套标准接口,即访问数据库的通用API,不同的数据库厂商根据各自数据库的特点去实现这些接口;

 

JDBC接口及数据库厂商实现:

  · 驱动管理     DriverManager  

  · 链接接口   Connection  ,DatabaseMetaData

  · 语句对象接口 Statement,  PreparedStatement,  CallableStatement

  · 结果集接口  ResultSet,  ResultSetMetaDate

 

JDBC使用步骤:

* 1.导入JDBC驱动jar;
* 2.注册JDBC驱动:
  - 参数:驱动程序类名
  - Class.forName("驱动程序类名")
* 3.获得Connertion对象:
   - 需要3个参数:url、username、password
   - 链接到数据库
* 4.创建Statement(语句)对象:
     - conn.createStatement()方法创建对象
  - 用于执行sql语句
  - execut(ddl)执行任何sql,常用于执行DDL
  - executeUpdate(dml)执行DML语句,如:insert、update、delete
  - executeQuery(dql)执行DQL语句,如:selest
* 5.处理sql执行结果:
  - execute(ddl)如果没有异常则成功;
       - executeUpdate(dml) 返回数字,表示更新"行"数量,报出异常则失败;
  - executeQuery(dql)返回ResultSet(结果集)对象,代表2维查询结果,使用for遍历处理,如果查询失败报出异常;
* 6.关闭数据连接!

##  处理结果集 ResultSet :

  ResultSet 代表DQL查询结果,是2维结果,其内部维护了一个读取数据的游标,默认情况在,游标在第一行数据之前,当调用next()方法时候,

游标会向下移动,并将返回结果集中是否包含数据,如果包含数据就返回true,结果集还提供了很好get方法用于获取结果集游标指向当前行数据;

 ## xx.net() 检查是否有行;

 

## 管理数据库连接:

  在软件中数据库连接使用非常频繁,如果每次都创建连接,就会造成代码的大量亢(kang)余,常规做法是建立数据链接工具类,封装数据库连接过程,

统一数据库连接过程,使用时候就可以简化代码;

 

 

JDBC 数据库连接池

   数据库连接池是管理并发访问数据库的理想解决方案;DriverManager管理数据库连接适合单线程使用,而在多线程并发情况下,

为了能够重用数据库连接,同时控制并发连接总数,保护数据库避免连接过载,一定要使用数据库连接池;

连接池原理:

 

###使用DBCP连接池

数据库连接池的开源实现非常多,DBCP是常用的连接池之一;

 

 

待续.....

转载于:https://www.cnblogs.com/cainiaobufei/p/10613298.html

你可能感兴趣的文章
hdu 1003 Max Sum (DP)
查看>>
学习进度表_二周
查看>>
tag标签
查看>>
TTS语言 录音功能
查看>>
MySQL 查询最大最小值优化
查看>>
软件工程的实践项目课程的自我目标
查看>>
Weak is not weak,Strong is not strong
查看>>
setsockopt 详解
查看>>
首次使用AWS服务器EC2
查看>>
POJ-1860-Currency Exchange
查看>>
[深度学习]受限玻尔兹曼机生成手写数字训练样本原理
查看>>
莫比乌斯反演
查看>>
Django Hello World
查看>>
分析rails日志,计算响应率
查看>>
PHP 提交checkbox表单时 判断复选框是否被选中
查看>>
day12-sqlalchemy 常用语法
查看>>
Interval GCD CH4302
查看>>
Vim + SpaceVim强大的Linux系统下的编辑器
查看>>
dxRibbonRadialMenu控件使用
查看>>
知识总结:测试用例
查看>>