JDBC连接数据库
•创建一个以JDBC连接数据库的程序,包含7个步骤:
1、加载JDBC驱动程序:
在连接数据库之前,首先要加载想要连接的数据库的驱动到JVM(Java虚拟机),
这通过java.lang.Class类的静态方法forName(String className)实现。
例如:
try{
//加载MySql的驱动类
Class.forName("com.mysql.jdbc.Driver") ;
}catch(ClassNotFoundException e){
System.out.println("找不到驱动程序类 ,加载驱动失败!");
e.printStackTrace() ;
}
成功加载后,会将Driver类的实例注册到DriverManager类中。
2、提供JDBC连接的URL
•连接URL定义了连接数据库时的协议、子协议、数据源标识。
•书写形式:协议:子协议:数据源标识
协议:在JDBC中总是以jdbc开始
子协议:是桥连接的驱动程序或是数据库管理系统名称。
数据源标识:标记找到数据库来源的地址与连接端口。
例如:(MySql的连接URL)
jdbc:mysql:
//localhost:3306/test?useUnicode=true&characterEncoding=gbk ;
useUnicode=true:表示使用Unicode字符集。如果characterEncoding设置为
gb2312或GBK,本参数必须设置为true 。characterEncoding=gbk:字符编码方式。
3、创建数据库的连接
•要连接数据库,需要向java.sql.DriverManager请求并获得Connection对象,
该对象就代表一个数据库的连接。
•使用DriverManager的getConnectin(String url , String username ,
String password )方法传入指定的欲连接的数据库的路径、数据库的用户名和
密码来获得。
例如:
//连接MySql数据库,用户名和密码都是root
String url = "jdbc:mysql://localhost:3306/test" ;
String username = "root" ;
String password = "root" ;
try{
Connection con =
DriverManager.getConnection(url , username , password ) ;
}catch(SQLException se){
System.out.println("数据库连接失败!");
se.printStackTrace() ;
}
4、创建一个Statement
•要执行SQL语句,必须获得java.sql.Statement实例,Statement实例分为以下3
种类型:
1、执行静态SQL语句。通常通过Statement实例实现。
2、执行动态SQL语句。通常通过PreparedStatement实例实现。
3、执行数据库存储过程。通常通过CallableStatement实例实现。
具体的实现方式:
Statement stmt = con.createStatement() ;
PreparedStatement pstmt = con.prepareStatement(sql) ;
CallableStatement cstmt =
con.prepareCall("{CALL demoSp(? , ?)}") ;
5、执行SQL语句
Statement接口提供了三种执行SQL语句的方法:executeQuery 、executeUpdate
和execute
1、ResultSet executeQuery(String sqlString):执行查询数据库的SQL语句
,返回一个结果集(ResultSet)对象。
2、int executeUpdate(String sqlString):用于执行INSERT、UPDATE或
DELETE语句以及SQL DDL语句,如:CREATE TABLE和DROP TABLE等
3、execute(sqlString):用于执行返回多个结果集、多个更新计数或二者组合的
语句。
具体实现的代码:
ResultSet rs = stmt.executeQuery("SELECT * FROM ...") ;
int rows = stmt.executeUpdate("INSERT INTO ...") ;
boolean flag = stmt.execute(String sql) ;
6、处理结果
两种情况:
1、执行更新返回的是本次操作影响到的记录数。
2、执行查询返回的结果是一个ResultSet对象。
• ResultSet包含符合SQL语句中条件的所有行,并且它通过一套get方法提供了对这些
行中数据的访问。
• 使用结果集(ResultSet)对象的访问方法获取数据:
while(rs.next()){
String name = rs.getString("name") ;
String pass = rs.getString(1) ; // 此方法比较高效
}
(列是从左到右编号的,并且从列1开始)
7、关闭JDBC对象
操作完成以后要把所有使用的JDBC对象全都关闭,以释放JDBC资源,关闭顺序和声
明顺序相反:
1、关闭记录集
2、关闭声明
3、关闭连接对象
if(rs != null){ // 关闭记录集
try{
rs.close() ;
}catch(SQLException e){
e.printStackTrace() ;
}
}
if(stmt != null){ // 关闭声明
try{
stmt.close() ;
}catch(SQLException e){
e.printStackTrace() ;
}
}
if(conn != null){ // 关闭连接对象
try{
conn.close() ;
}catch(SQLException e){
e.printStackTrace() ;
}
}
分享到:
相关推荐
在深入了解JDBC的具体用法之前,我们先简要回顾一下JDBC的基本概念: 1. **驱动管理器(DriverManager)**:用于加载JDBC驱动并创建与数据库之间的连接。 2. **连接(Connection)**:表示到数据库的连接。 3. **...
#### 二、JDBC编程步骤 接下来,我们将介绍如何通过Java中的JDBC来执行上述SQL语句。 1. **加载驱动** - 使用`Class.forName()`来加载特定的数据库驱动类。 - 或者使用`Class.forName().newInstance()`来实例化...
在讲解JDBC之前,我们先回顾一下相关背景知识。JBuilder是一款集成开发环境,专用于设计和开发Java应用程序。Swing是Java AWT(Abstract Window Toolkit)的扩展,提供了更多的组件和功能,用于构建图形用户界面...
#### 连接MySQL数据库步骤 ##### 步骤一:打开MyEclipse并进入数据库视图 - 首先,启动MyEclipse。 - 接着,通过菜单栏中的`Window` > `Open Perspective` > `MyEclipse Database Explorer`来切换至数据库管理界面...
7. **连接数据库**: JDBC(Java Database Connectivity)是Java连接数据库的标准接口,包括加载驱动、建立连接、执行SQL语句等步骤。 8. **事务处理**: 对数据库操作进行原子性、一致性、隔离性和持久性的管理,确保...
在进入Java EE的数据库编程之前,我们先来回顾一下数据库的基础知识: - **数据库(Database)**:用来存储数据的集合。 - **表(Table)**:数据库中的基本单元,包含行(记录)和列(字段)。 - **关系型数据库...
它支持多种数据库连接方式,包括ODBC(开放数据库连接)和JDBC(Java数据库连接)。用户可以根据自己的需求选择合适的连接参数,进行远程或本地数据库的访问。此外,它还提供查询执行历史记录,方便用户回顾和重复...
- **JSP与数据库交互**:JSP页面可以通过Java Database Connectivity (JDBC) API与数据库进行通信,实现数据查询、插入、更新和删除等操作。 #### 二、JSP在Oracle数据库中的应用 - **Oracle JSP实现**:本书详细...
- 作用: 显示当前数据库连接的详细信息,包括数据库产品名称、版本、JDBC驱动程序等。 - 使用方法: 可以帮助开发者了解连接状态,便于调试。 ##### 3. Connections (连接) - 作用: 展示当前所有活动的数据库连接。...
7. **数据库连接与API**:在Web应用中,通常使用数据库连接池管理数据库连接,并通过数据库API(如JDBC、ODBC)与数据库进行交互。 8. **Web应用集成**:学习如何在Web框架(如PHP、ASP.NET、Java Spring等)中集成...
系统前端可能使用Swing或JavaFX构建用户界面,后端使用Java的JDBC接口连接数据库,实现数据的增删查改操作。同时,考虑了异常处理和事务管理,确保系统的稳定运行。 5. 系统测试:进行了功能测试、性能测试和兼容性...
学习JDBC主要包括以下几个步骤:加载数据库驱动、建立数据库连接、创建Statement或PreparedStatement对象、执行SQL语句、处理结果集以及关闭连接。此外,了解批处理、连接池和JNDI(Java Naming and Directory ...
本文将详细介绍如何在JSP中连接三种常见的数据库:Oracle、SQL Server以及DB2,并通过示例代码来演示具体的操作步骤。 #### 二、基础知识回顾 在深入讨论之前,我们需要了解一些基础知识: 1. **JDBC (Java ...
在深入探讨如何使用JSP连接不同的数据库之前,我们先来简要回顾一下几个关键概念: 1. **JDBC**:Java Database Connectivity,是Java平台上的数据库访问技术,为开发者提供了一个标准API来访问各种类型的数据库。 ...
在深入了解JSP与数据库的连接方式之前,我们先简要回顾一下几个关键概念: 1. **JSP**: Java Server Pages 的简称,是一种用于创建动态网页的技术。它允许在HTML文档中直接嵌入Java代码片段和声明。 2. **SQL ...