1.框架介绍
JDBC(Java DataBase Connectivity,java数据库连接):他是Sum公司为所有数据库厂商提供的一组作为接口集合,各个数据库厂商分别提供关于这组接口的实现,已达到通过JDBC技术操作的目的,是一种用于执行SQL语句的Java API,可以为多种关系数据库提供统一访问,它由一组用Java语言编写的类和接口组成名。
2.优点(缺点) 即框架特点
优点:jdbc就是访问数据库底层类!执行效率最快!
缺点:a.代码过于
b.没有提供对结果集的封装
c.解耦性不强(如连接信息写在java,sql语句写在Java中)
3.搭建流程(代码) 这个框架怎么配
1、加载JDBC驱动程序:
Class.forName("com.mysql.jdbc.Driver") ;
2、提供JDBC连接的URL
String url="jdbc:mysql://localhost:3306/test";
3 、连接MySql数据库,用户名和密码都是root
String username = "root" ;
String password = "root" ;
4、要连接数据库
需要向java.sql.DriverManager请求并获得Connection对象,该对象就代表一个数据库的连接。方法传入指定的欲连接的数据库的路径、数据库的用户名和密码来获得。
Connection con = DriverManager.getConnection(url ,username ,password ) ;
String sql=”select * from 表明”。//准备sql语句
5、创建一个Statement对象
1执行静态SQL语句。通常通过Statement实例实现。
2、执行动态SQL语句。通常通过PreparedStatement实例实现。
3、执行数据库存储过程。通常通过CallableStatement实例实现
Statement stmt = con.createStatement() ;
PreparedStatement pstmt = con.prepareStatement(sql) ; //常用这种
CallableStatement cstmt =con.prepareCall("{CALLdemoSp(? , ?)}") ;
6、执行SQL语句, Statement接口提供了三种执行SQL语句的方法executeQuery 、executeUpdate 和execute
ResultSet rs = stmt.executeQuery(sql) ;
6、处理结果
两种情况:
1、执行更新返回的是本次操作影响到的记录数。
2、执行查询返回的结果是一个ResultSet对象。
• ResultSet包含符合SQL语句中条件的所有行,并且它通过一套get方法提供了对这些 行中数据的访问。
• 使用结果集(ResultSet)对象的访问方法获取数据:
while(rs.next()){
String name = rs.getString("name") ;
String pass = rs.getString(1) ; // 此方法比较高效
}
6、关闭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() ;
}
4.调用流程
0、导包
1、声明JDBC对象 connection ,PreparedStatement,ResultSet
2、加载驱动 (Class.forName(“驱动”))
3、声明连接信息 (数据库地址,用户,密码)
4、建立连接 (DriverManager.getConnection(url ,username ,password ) )
5、创建Statement对象 (con.prepareStatement(sql))
6、发送SQL
6_2:如果是查询语句需要的结果集对象(ResultSet)
7、关闭JDBC对象 close()方法关闭
JDBC的原理就是通过Connection这个类获取数据库的连接,
然后通过PreparedStatement类处理SQL语句,再通过它的.setObject方法传入数据,
最后通过方法.executeUpdate()和.executeQuery()执行更新,这就是JDBC的基本原理。
总结
本篇文章按照步骤分开写,让逻辑更为清晰,可将以上代码合并在一起就是jdbc的执行过程。