JDBC基本使用
一、了解JDBC
(1) JDBC是以统一方式访问数据库的API
(2) JDBC提供:
独立于平台的数据库访问
位置透明
对专有数据库的问题时透明的
二、了解JDBC驱动程序
(1) JDBC Drivers是实现数据库操作的类
(2) Drivers分成两类:
2-层——客户直接和数据库会话
3-层——客户与代表数据库的中间层(WebLogic Server)会话
其实也就是:两层架构直接与数据库进行处理
三层架构加载数据库的中间层
这些跟.net几乎没什么差别。我们继续来看一个图:

我们看这个图有什么想发?
第4种:居于Java特色的。不需要安装软件和客户端;跟位置与平台是没有关系的。,
第1、2、4:都是两层的类型,直接连接到数据库的
第3种:基于NetworkServer集中式的监控,屏蔽丢不同的平台。在1、2、4的基础上,通过webserver来连接的一种资源。是一种特殊的jdbC的类型
三、使用JDBC直接访问数据库
(1) 直接访问数据库由下列组成:
加载JDBC驱动器类
我们看一下直接连接数据库的示例:
(2) 使用基本的JDBC命令
- import java.sql.*;
- try{
- class.forName("com.pointbase.jdbc.jdbcUniversalDriver");
- Connection con=DriverManager.getConnect("jdbc:pointbase;//server:port/MyDatabase");
- Statement stmt=con.createStatement();
- String sql="select * from mytable";
- ResultSet res=stmt.executeQuery(sql);
- while(res.next()){
- String col1=res.getString("MYCOLUMN1");
- int col2=res.getInt("MYCOLUMN2");
- }catch(Exception e){...}
- }
四、使用多层(Type3)Drivers
要使用多层体系结构,必须至少配置一个连接池(Connection Pool和一个数据源(DataSource)

五、连接池Connection
连接池:
消除频繁建立连接所需的负载
是用于管理数据库连接的管理对象
提供可共享,安全的连接

六、数据源Data Sources
Data Sources是:
从连接池中提供连接的被管理的工厂对象
绑定到JNDI并使用管理控制台配置

七、我们通过数据源Data Sources访问数据库
(1) 使用DataSource:
先在JNDI中查找到它
然后从DataSource获得一个连接
使用数据源连接数据库的示例:
- import java.sql.*;import javax.sql.*;import javax.naming.*;...
- try{
- context ctx=new InitialContext();
- DataSource ds=(DataSource)ctx.lookup("TestDataSource");
- Connection con=ds.getConnection();
- Statement stmt=con.createStatement();
- String sql="SELECT * FROM MYTABLE";
- ResultSet res=stmt.executeQuery(sql);
- While(res.next()){
- String col1=res.getString("MYCOLUM1");
- ...
- }
- con.close();
- }catch(Exception e){...}
八、Statements和Prepared Statements
(1) Statement对象含有与数据库交互的SQL查询或更新语句
使用Statement对象查询数据库的示例:
- Statement stmt=con.createStatement();
- String sql="SELECT * FROM MYTABLE";
- ResultSet res=stmt.excuteQuery(sql);
使用PreparedStatement对象查询数据库的示例:
- String sql="SELECT * FROM MYTABLE WHERE COL1=? AND COL2=?";
- PreparedStatement pStatement=con.prepareStatement(sql);
- pStatement.setString(1,searchVariableString);
- pStatement.setInt(2,searchVariableInt);
- ResultSet rs=pStatement.executeQuery();
这只是初步了解,还需要应用到项目当中去呀。
JDBC基本使用的更多相关文章
- Java数据库连接技术——JDBC
大家好,今天我们学习了Java如何连接数据库.之前学过.net语言的数据库操作,感觉就是一通百通,大同小异. JDBC是Java数据库连接技术的简称,提供连接各种常用数据库的能力. JDBC API ...
- 玩转spring boot——结合AngularJs和JDBC
参考官方例子:http://spring.io/guides/gs/relational-data-access/ 一.项目准备 在建立mysql数据库后新建表“t_order” ; -- ----- ...
- [原创]java使用JDBC向MySQL数据库批次插入10W条数据测试效率
使用JDBC连接MySQL数据库进行数据插入的时候,特别是大批量数据连续插入(100000),如何提高效率呢?在JDBC编程接口中Statement 有两个方法特别值得注意:通过使用addBatch( ...
- JDBC MySQL 多表关联查询查询
public static void main(String[] args) throws Exception{ Class.forName("com.mysql.jdbc.Driver&q ...
- JDBC增加删除修改
一.配置程序--让我们程序能找到数据库的驱动jar包 1.把.jar文件复制到项目中去,整合的时候方便. 2.在eclipse项目右击"构建路径"--"配置构建路径&qu ...
- JDBC简介
jdbc连接数据库的四个对象 DriverManager 驱动类 DriverManager.registerDriver(new com.mysql.jdbc.Driver());不建议使用 ...
- JDBC Tutorials: Commit or Rollback transaction in finally block
http://skeletoncoder.blogspot.com/2006/10/jdbc-tutorials-commit-or-rollback.html JDBC Tutorials: Com ...
- FineReport如何用JDBC连接阿里云ADS数据库
在使用FineReport连接阿里云的ADS(AnalyticDB)数据库,很多时候在测试连接时就失败了.此时,该如何连接ADS数据库呢? 我们只需要手动将连接ads数据库需要使用到的jar放置到%F ...
- JDBC基础
今天看了看JDBC(Java DataBase Connectivity)总结一下 关于JDBC 加载JDBC驱动 建立数据库连接 创建一个Statement或者PreparedStatement 获 ...
- Spring学习记录(十四)---JDBC基本操作
先看一些定义: 在Spring JDBC模块中,所有的类可以被分到四个单独的包:1.core即核心包,它包含了JDBC的核心功能.此包内有很多重要的类,包括:JdbcTemplate类.SimpleJ ...
随机推荐
- java wait和notify及 synchronized sleep 总结
java 中线程我一直弄不清线程锁等 所以写了一些例子验证看法: 在这之前先看下API中wait中的解释: wait:方法来之java.lang.Objetc 方法翻译:在其他线程调用此对象的 not ...
- findViewById中NullPointerException的错误
最近在弄一个对话框的登录时,发现一个总是报NullPointerException的错误,折腾了两小时,一直没有发现细小的区别..先上图,一边说明原因 首先是 Activity类中定义的findVie ...
- React Native之Navigator
移动应用很少只包含一个页面.从你添加第二个页面开始,就得考虑如何管理多个页面间的跳转了. 导航器正是为此而生.它可以管理多个页面间的跳转,也包含了一些常见的过渡动画,包括水平翻页.垂直弹出等等. Na ...
- 海量数据挖掘MMDS week7: 相似项的发现:面向高相似度的方法
http://blog.csdn.net/pipisorry/article/details/49742907 海量数据挖掘Mining Massive Datasets(MMDs) -Jure Le ...
- Android图片色彩变幻
最近在做图片相关的应用,所以就各方积累到一些常用的操作,一般来说会有多种方式来实现这一功能,比如 采用色度变换 采用ColorMatrix颜色矩阵 采用对像素点的直接操作 等等,今天就复习一下第一种方 ...
- javascript之prototype原型属性案例
练习: 给字符串对象添加一个toCharArray的方法,然后再添加一个reverse(翻转)的 方法 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML ...
- numpy教程:矩阵matrix及其运算
http://blog.csdn.net/pipisorry/article/details/48791403 numpy矩阵简介 NumPy函数库中存在两种不同的数据类型(矩阵matrix和数组ar ...
- Android View事件机制一些事
本文主要讲述: 自己对View事件机制的一些理解 在项目中遇到的一些坑,解决方案 收集了一些View的事件机制问题 事件的分发原理图 对于一个root viewgroup来说,如果接受了一个点击事件, ...
- Libgdx1.5.3发布
- API更改:TextField#setRightAlign改成TextField#setAlignment - I18NBundle 现在兼容Android2.2 - 修复GWT反射包括3D粒子 ...
- 序列化与反序列化中serialVersionUID的作用(通俗易懂)
serialVersionUID:字面意思上是序列化的版本号,这个在刚刚接触java编程时,学序列化大家一般都不会注意到,在你一个类序列化后除非你强制去掉了myeclipse中warning的功能,在 ...