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 ...
随机推荐
- "ORA-20100: 为 FND_FILE 创建文件 o0003167.tmp 失败"
今天在运行请求时候得到如下的错误日志: 原因:由于ORA-20100:为FND_FILE创建文件o0003167.tmp失败. 在请求日志的错误原因中您会找到更详细的信息. 查找了一些资料,总结 ...
- 高斯函数 --> 高斯分布(正态分布)
具有如下形式的函数就是高斯函数. 其中a,b,c都是实数常数,a大于0 .由于在博客中写数学公式比较麻烦,还是直接放照片吧. 字写的很难看,不过应该可以看清楚.:(
- (NO.00005)iOS实现炸弹人游戏(六):游戏数据的初始化(三)
大熊猫猪·侯佩原创或翻译作品.欢迎转载,转载请注明出处. 如果觉得写的不好请告诉我,如果觉得不错请多多支持点赞.谢谢! hopy ;) 现在我们来看看实际初始化地图的randomCreateMap方法 ...
- UNIX网络编程——僵尸进程
在fork()/exec()过程中,假设子进程结束时父进程仍存在,而父进程fork()之前既没安装SIGCHLD信号处理函数调用waitpid()等待子进程结束,又没有显式忽略该信号,则子进 ...
- HTTP请求方法
HTTP请求方法 根据HTTP标准,HTTP请求可以使用多种请求方法. HTTP1.0定义了三种请求方法: GET, POST 和 HEAD方法. HTTP1.1新增了五种请求方法:OPTIONS, ...
- 【一天一道LeetCode】#100. Same Tree(100题大关)
一天一道LeetCode 本系列文章已全部上传至我的github,地址:ZeeCoder's Github 欢迎大家关注我的新浪微博,我的新浪微博 欢迎转载,转载请注明出处 (一)题目 Given t ...
- Mybatis逻辑分页原理解析RowBounds
Mybatis提供了一个简单的逻辑分页使用类RowBounds(物理分页当然就是我们在sql语句中指定limit和offset值),在DefaultSqlSession提供的某些查询接口中我们可以看到 ...
- java 如何自定义异常 用代码展示 真心靠谱
先建两个自定义的异常类 ChushufuException类 class ChushufuException extends Exception { public ChushufuException( ...
- Rust语言
Rust语言 https://doc.rust-lang.org/stable/book/ http://www.phperz.com/article/15/0717/141560.html Rust ...
- Mahout 系列之--canopy 算法
Canopy 算法,流程简单,容易实现,一下是算法 (1)设样本集合为S,确定两个阈值t1和t2,且t1>t2. (2)任取一个样本点p属于S,作为一个Canopy,记为C,从S中移除p. (3 ...