JDBC连接数据库的一般步骤 步骤如下:
前提是导入 java.sql.*;
(1) : 加载驱动程序
Class.forName("com.microsoft.sqlserver.jdbc.SQLserverDriver");
(2) : 建立连接(通过驱动管理器)
Connection con = DriverManager.getConnection(URL, userName,userPwd);
(这里的URL = "jdbc:sqlserver://服务器名称:1433; DatabaseName = 数据库名称")
(后两个参数userName和userPwd分别是用户和密码,,如果没有的话,可以不写)
(3) : 建立Statement (通过Connection对象进行创建),,
Statement st = con.createStatement();
//建立 Statement 之后,就可以使用Statement的对象 st 来执行sql语句了。。
例如: st.executeUpdate("sql语句")。。。。详情请查阅API
(4) : 关闭连接
con.close();
注意:连接sql2000和sql2005时,会有一定的差别
在sql server 2000 中加载驱动和URL路径的语句是
String driverName = "com.microsoft.jdbc.sqlserver.SQLServerDriver";
String dbURL = "jdbc:microsoft:sqlserver://localhost:1433; DatabaseName=sample";
而sql server 2005 中加载驱动和url的语句则为
String driverName = "com.microsoft.sqlserver.jdbc.SQLServerDriver";
String dbURL = "jdbc:sqlserver://localhost:1433; DatabaseName=sample";
----------------------------------------
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() ;
}
}
------------------------------------------------
步骤其实都差不多,不同的数据库有不同的Drivername,url也都不相同,新手同学可以先死记住。
------------------------------------------------
分享下:
JDBC里统一的使用方法
Class.for(jdbcDriverName);
Connection conn= DriverManager.getConnection(url,user,password);
MySQL
Class.forName("com.mysql.jdbc.Driver");
Connection con = DriverManager.getConnection("jdbc:mysql://host:port/database","user","password");
Oracle数据库(thin模式)
Class.forName("oracle.jdbc.driver.OracleDriver");
Connection con = DriverManager.getConnection("jdbc:oracle:thin:@host:port:databse","user","password");
Microsoft SQL Server
Class.forName("net.sourceforge.jtds.jdbc.Driver ");
Connection con = DriverManager.getConnection("jdbc:jtds:sqlserver://host:port/database","user","password");
or
Connection con = DriverManager.getConnection("jdbc:jtds:sybase://host:port/database","user","password");
相关推荐
本篇文章将探讨几种常见的数据库连接池的使用比较,包括Proxool、DBCP、C3P0,并通过配置文件(如`proxool.xml`、`dbcp.xml`和`c3p0.xml`)来展示它们的配置细节。 首先,我们来看Proxool,它是一个轻量级的数据库...
本文将深入解析几种常用的数据库连接池——Apache DBCP、C3P0、Proxool、BoneCP的详细配置参数,帮助开发者更好地理解和应用这些技术。 ### Apache DBCP **dataSource**: 配置数据源,通常在应用服务器的配置文件...
在Spring框架中,整合数据库连接是开发Web应用的常见任务,它提供了多种方式来管理数据库连接池,确保高效、稳定的数据交互。以下是Spring整合数据库连接的三种主要方式:DBCP、C3P0和Proxool,以及它们各自的特点和...
下面分别介绍几种常见数据库的连接方式: 1. **Oracle数据库**:使用`oracle.jdbc.driver.OracleDriver`驱动,URL格式为`jdbc:oracle:thin:@<hostname>:<port>:<sid>`。 2. **DB2数据库**:使用`...
在给定的文件中,提到了两种数据库的连接方式:SQLServer和MySQL,都是通过Java编程语言实现的。下面将详细讲解这两种数据库的连接配置以及XML文件在数据库连接中的作用。 首先,我们来看SQLServer的连接示例...
本文将详细讲解在Tomcat中配置数据库连接池的几种常见方法,帮助开发者实现高效、稳定的数据库访问。 一、Apache Commons DBCP Apache Commons DBCP是Apache组织提供的一款开源数据库连接池组件,它基于Jakarta-...
数据库连接池是一种用于管理数据库连接的技术。它维护了一组预创建的数据库连接,并允许应用程序从这些连接中获取和释放资源,而不是每次都需要创建新的连接。这样可以显著提高应用程序的性能和响应时间,尤其是在...
连接池是一种数据库连接复用的技术,能够预先创建一定数量的数据库连接,并将其保存在一个池中。当应用程序需要访问数据库时,可以从池中获取一个已经创建好的连接;使用完毕后,将连接放回池中而不是关闭,以便后续...
但更常见的是将业务逻辑和数据访问层分离,使用Servlet或Controller处理数据库操作,而JSP只负责展示视图。使用PreparedStatement预编译SQL语句可以防止SQL注入攻击,并提高性能。 6. **DAO(Data Access Object)...
其中,`name`是数据源的JNDI名称,`auth`指定认证方式,`type`指定数据源类型,`driverClassName`是数据库驱动类名,`url`是数据库连接URL,`username`和`password`是数据库登录凭证,`maxActive`、`maxIdle`和`...
根据描述中提到的“Tomcat报错”,可能存在以下几种情况: 1. **驱动问题**:确认JDBC驱动是否正确且完整地添加到了Tomcat的库中。 2. **配置问题**:检查`Context.xml`和`web.xml`文件中的配置是否正确无误。 3. *...
### 使用连接池连接数据库 ...使用JNDI配置和管理数据源是一种常见且有效的实践方式,特别是在大型企业级应用中更是不可或缺。正确理解和运用这些技术,将有助于开发者构建出更加稳定、高效的软件系统。
这里,`name`属性是我们将要在应用中使用的JNDI名称,`driverClassName`是数据库驱动类名,`url`是数据库连接地址,`username`和`password`是数据库认证信息,`maxActive`等属性控制连接池的行为。 然后,在你的Web...
这可以通过以下几种方式实现: 1. 将JAR包复制到项目的`lib`目录下。 2. 在IDE如Eclipse或IntelliJ IDEA中,将JAR包添加到项目的构建路径。 3. 如果使用Maven或Gradle等构建工具,可以在配置文件中指定依赖。 在...
3. **数据库操作**:编写插入和查询的SQL语句,处理用户的提交请求,将新留言保存到数据库,并更新显示的留言列表。 4. **错误处理**:使用`try-catch`块捕获可能出现的异常,提供友好的错误提示。 5. **安全性考虑*...
综上所述,DBCP数据库连接池是Java Web开发中常用的一种数据库连接管理工具,通过合理的配置和使用,可以显著提高应用的性能和稳定性。在实际项目中,结合Spring等框架,可以更便捷地管理和使用数据库连接。确保正确...
8. **分别查询Oracle、SQL Server、JDataStore上下文并执行测试源代码后的结果集**:对每种数据库执行查询操作,并展示结果集,以验证连接池和数据源配置的有效性。 通过上述步骤,不仅可以在WebLogic中成功建立...
在Spring Boot项目中,我们经常会遇到需要连接多个数据库的需求,比如主从数据库、读写分离等场景。本配置示例将详细介绍如何在Spring ...通过这种方式,我们可以灵活地管理和操作多个数据库,满足复杂的应用场景需求。