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 ...
随机推荐
- MVPHelper更新日志 --- 新增常规分包模式
MVPHelper是一款可以自动生成MVP接口以及实现类的android studio插件,彻底解放双手! MVPHelper更新版本啦. 由于之前只支持contract模式,不是很符合大众口味 所以 ...
- 匿名内部类使用外面的类为什么要用final型
从程序设计语言的理论上:局部内部类(即:定义在方法中的内部类),由于本身就是在方法内部(可出现在形式参数定义处或者方法体处),因而访问方法中的局部变量(形式参数或局部变量)是天经地义的.是很自然的 为 ...
- JAVA之旅(十七)——StringBuffer的概述,存储,删除,获取,修改,反转,将缓存区的数据存储到数组中,StringBuilder
JAVA之旅(十七)--StringBuffer的概述,存储,删除,获取,修改,反转,将缓存区的数据存储到数组中,StringBuilder 讲完String,我们来聊聊他的小兄弟 一.StringB ...
- 【一天一道LeetCode】#94. Binary Tree Inorder Traversal
一天一道LeetCode 本系列文章已全部上传至我的github,地址:ZeeCoder's Github 欢迎大家关注我的新浪微博,我的新浪微博 欢迎转载,转载请注明出处 (一)题目 Given a ...
- Linux多线程实践(10) --使用 C++11 编写 Linux 多线程程序
在这个多核时代,如何充分利用每个 CPU 内核是一个绕不开的话题,从需要为成千上万的用户同时提供服务的服务端应用程序,到需要同时打开十几个页面,每个页面都有几十上百个链接的 web 浏览器应用程序,从 ...
- ECMAScript 6之变量的解构赋值
1,数组的解构赋值 基本用法 ES6允许按照一定模式,从数组和对象中提取值,对变量进行赋值,这被称为解构(Destructuring). 以前,为变量赋值,只能直接指定值. var a = 1; va ...
- (三十四)NavigationController初步
为了了解底层,首先不基于UIWindow而基于UIWindow来创建App. 由于Xcode6没有以前的基于UIWindow的空项目,所以选择SingleView,然后删除storyboard,移除B ...
- MySQL学习笔记_9_MySQL高级操作(上)
MySQL高级操作(上) 一.MySQL表复制 create table t2 like t1; #复制表结构,t2可以学习到t1所有的表结构 insert into t2 ...
- EBS Concurrent Manager(并发管理器)异常处理[final]
来自:http://blog.itpub.net/35489/viewspace-742191/ 有时候我们在通过 adstpall.sh 关闭应用后,然后再使用adstrtal.sh开启.发现并发 ...
- (NO.00001)iOS游戏SpeedBoy Lite成形记(十五)
现在啃第2个问题:如何让玩家输入赌注金额. 实现的方法有很多种,比如可以限制玩家只能从特定的金额中选择,把每个选择做成一个按钮即可.以下是一个假想选择窗口的示意图: 这样没有玩家的输入问题了.缺点是不 ...