数据库系统概念:JDBC
import java.sql.*;
public class DataBase {
public static void main() {
}
}
/*
5.1.1 JDBC
*/
class JDBC{
static void JDBCExample(String userid,String passwd){
/*
*/
try{
/*
加载驱动器类,参数为直线了java.sql.Driver接口的实体类,这个接口的功能是
实现了不同层面的操作之间的转换,一边是产品类型无关的JDBC操作、另一边是与产品
相关的、在所使用的特定数据库管理系统中完成的操作。
*/
Class.forName("oracle.jdbc.driver.OracleDriver");
/*
调用DriverManager类的getConnection方法来打开一个数据库连接。
URI中指代的意义:
jdbc:oracle:thin:与数据库通信所使用的协议
db.yale.edu:服务器所在主机的名称
1521:端口号
univdb:所连接的数据库实例
*/
Connection conn = DriverManager.getConnection("jdbc:oracle:thin:@db.yale.edu:1521:univdb",
userid,
passwd);
/*
一旦打开了一个数据库连接,程序就可以利用该连接来向数据库发送SQL语句用于执行。这是
通过Statement类的一个实例来完成的。一个Statement对象并不代表SQL语句奔上,而是
实现了可以被Java程序调用的一些方法,通过参数来传递SQL并被数据库系统所执行。我们
的例子在连接变量conn上创建了一个Statement句柄。
我们即可以用executeQuery函数,又可以用executeUpdate函数来执行一条语句~
*/
Statement stmt = conn.createStatement();
stmt.executeUpdate("insert into instructor values('','','')");
/*
*/
ResultSet set = stmt.executeQuery("");
while (set.next()) {
//Do Something...
}
ResultSetMetaData rsmd = set.getMetaData();
; i < rsmd.getColumnCount(); i++) {
System.out.println(rsmd.getColumnName(i));
System.out.println(rsmd.getColumnType(i));
}
} catch (ClassNotFoundException e) {
e.printStackTrace();
} catch (SQLException e) {
e.printStackTrace();
}
}
}
/*
5.1.1.5 可调用语句
JDBC提供了CallableStatement接口来允许调用SQL的存储过程和函数,此接口对函数
和过程所扮演的角色跟prepareStatement对查询所扮演的角色一样。函数返回值和过程
的对外参数的数据类型必须先用方法registerOutParameter()注册,它们可以用与结果
集用的方法类似的get方法是获取。
*/
/*
5.1.1.5 元数据特性
一个Java应用程序不包括数据类型存储的数据的声明。这些声明是SQL数据定义语言DDL的一
部分。因此使用JDBC的java程序,必须要么将关于数据库模式的假设硬编码到程序中,要么
直接在运行时从数据库系统中得到那些信息。后一种方法更可取,因为它使得应用程序可以更
健壮的处理数据库模式的变化。
我们使用executeQuery方法查询时,查询结果被封装在一个ResultSet对象中。接口ResultSet
中有一个getMetaData()方法,它返回一个包含结果集元数据的ResultSetMetaData对象,
ResultSetMetaData对象进一步又包括查找元数据的方法,例如结果集的列数,或者某个特定
列的数据类型。这样,即使不知道结果的模式,我们也可以方便地执行查询。
DatabaseMetaData接口提供了查找数据库元数据的机制。接口Connection包含一个getMeteData
方法,用于返回一个DatabaseMetaData对象。接口DatabaseMetaData进一步又包含了大量的方法
可以用于获取程序所连接数据库和数据库系统的元数据。
*/
/*
*/
数据库系统概念:JDBC的更多相关文章
- 《数据库系统概念》1-数据抽象、模型及SQL
DBMS(database-management system)包括数据库和用于存取数据的程序,DBMS的基本目标是为数据的存取提供方便.高效的方式,此外对大多数企业来说,数据是非常重要的,所以DB ...
- 数据库系统概念:SQL的数据类型与模式、授权
public class DataBase { public static void main() { } } /* 4.5 SQL的数据类型与模式 4.5.1 SQL的日期与时间类型 SQL标准支持 ...
- 《数据库系统概念》10-ER模型
通过建立实体到概念模型的映射,Entity-Relationship Model可以表达整个数据库的逻辑结构,很多数据库产品都采用E-R模型来表达数据库设计. 一.E-R模型采用了三个基本概念:实体集 ...
- SQLServer数据库系统概念
数据模型是一种抽象模型,现实世界中的客观事物是彼此相互联系的 (1)数据模型是一组集成的概念,用户描述和操作组织内的数据,数据间的联系以及对数据的约束,它包含了数据结构,数据操作和完整性约束 (2)概 ...
- 数据库系统概念:基础的SQL
public class DataBase { public static void main() { } } /* 3.1 SQL查询语言概览 SQL语言有一下几个部分: 数据定义语言:提供定义关系 ...
- 《数据库系统概念》11-扩展的E-R特性
虽然基本的E-R特性可以应对大部分数据库建模,但为了使用方便,也提供扩展的E-R特性 一.特化Specialization有时一个实体集会保护若干子集,这些子集各自具有不同的属性.比如person可 ...
- 《数据库系统概念》4-DDL、集合运算、嵌套子查询
一.DDLa) SQL Data DefinitionSQL的基本数据类型有char(n).varchar(n).int.smallint.numeric(p,d).real,double preci ...
- JDBC的介绍2
一.基础知识 1. 数据持久化 持久化(persistence):对象在内存中创建后,不能永久存在.把对象永久的保存起来就是持久化的过程.而持久化的实现过程大多通过各种关系数据库来完成. 持久化的主要 ...
- 第16讲:ODBC&JDBC简介
一.ODBC简介 1. ODBC的概念 ①ODBC:Open DataBase Connection,即开放数据库连接 ②ODBC是一种标准,它规定了不同语言的应用程序与不同数据库服务器之间通讯的方式 ...
随机推荐
- socket上http协议应用(使用socket进行http通信的例子,准备好报头以后,简单read/write就可以了)
前几天看socket本有点晕, 好不容易弄明白了,才发现公司服务器用的是http的. 找了好久也没发现linux下直接用http的api, 不过今日偶然发现了使用socket进行http通信的例子, ...
- HTML5离线缓存攻击测试(二)
经过昨天的测试,发现使用离线缓存的网站会被攻击.但是,不使用离线缓存的网站就真的不会受到这样的攻击么? 据我理解,按照标准当浏览器请求manifest文件时,若没有请求到,或者文件发生改变,应当不使用 ...
- UWP开发-获取设备唯一ID
EasClientDeviceInformation deviceInfo = new EasClientDeviceInformation(); this.showDeviceInfo.Items. ...
- Android零基础入门第69节:ViewPager快速实现引导页
在很多APP第一次启动时都会出现引导页,在一些APP里面还会包括一些左右滑动翻页和页面轮播切换的情况.在之前也已经学习了AdapterViewFlipper和ViewFlipper,都可以很好的实现, ...
- ASP.NET MVC控制器Controller中参数
前述文章参见:ASP.NET MVC控制器Controller 绪论 之前的控制器返回的均为常量字符串,接下来展示如何获取请求传来的参数,而返回"动态"的字符串. 可以在操作方法B ...
- Ptypes一个开源轻量级的c++库,包括对一些I/O操作、网络通信、多线程和异常处理的封装
C++开源项目入门级:Ptypes Ptypes一个开源轻量级的c++库,包括对一些I/O操作.网络通信.多线程和异常处理的封装.虽然代码有限,包括的内容不少,麻雀虽小,五脏俱全. 提高: ...
- Linux编辑器Vim和Emacs入门
sudo 命令 debian系统没有自带,需要安装: apt-get install sudo 安装位置为 /usr/bin/sudo,对应配置文件为 /etc/sudoers sudoers授权格式 ...
- Qt的槽可以使用默认参数
引用自:http://www.ibm.com/developerworks/cn/linux/guitoolkit/qt/signal-slot/ 的一篇经典文章,是关于Qt的信号和槽的分析的.看年份 ...
- http 报错码对应的错误原因
转:http://blog.csdn.net/cutbug/article/details/4024818 1xx - 信息提示这些状态代码表示临时的响应.客户端在收到常规响应之前,应准备接收一个或多 ...
- F4帮助
在INITIALIZATION之后添加 AT SELECTION-SCREEN ON VALUE-REQUEST FOR s_month-low 事件,s_month-low为要添加的搜索帮助. 下面 ...