JDBC学习(一)
jdbc简介
简介
JDBC是一种用于执行SQL语句的Java APi,可以为多种关系数据库提供统一访问。
JDBC可以在各种平台上使用java,如windows、Mac OS等。
JDBC库包括通常与数据库使用相关的API:
-连接数据库。
-创建SQL或者MySql语句。
-在数据库中执行SQL活MySql查询。
-查看和修改生成的记录。
体系结构
JDBC:提供了应用程序到数据库的连接规范。
JDBC驱动程序:连接数据库的驱动程序的实现。
JDBC的核心组件
1.DriverManager:管理数据库驱动程序列表。
2.Driver:处理与数据库服务器的通信。
3.Connection:具有用于连接数据库的所有方法。
4.Statem:使用Statemen创建的对象将SQL语句提交到数据库。
5.ResSet:返回的结果集。
6.SQLEception:异常处理。
JDBC的使用步骤
1:导入JDBC的jar包。
在项目中创建lib文件夹,导入下载好的jar包,导入包后记得add as library。
2.注册JDBC驱动程序。
推荐用法:
Class.forName(“com.mysql.jdbc.Driver”);
需要用trycatch处理一下。
也可以使用:
DriverManager.registerDriver()方法,可能会占用资源。
3.创建连接
Connection connection = null;
String url = “jdbc:mysql://localhost:3306/mydb?useUnicode&characterEncoding=utf-8”;
String user = “root”;
String password = “1234”;
connection = DriverManager.getConnection(url,user,password);
4.执行查询
这里需要设置sql语句
String sql = “Select * from table where id = ? ”;
然后设置statement对象,也可以使用高级一点的prepareStatement,比较安全高效、。
通过connection创建。
prepareStatement = connection.prepareStatement(sql);
prepareStatement.setObject(1,***);
5.处理结果
resultSet = prepareStatemen.executeQuery();
这里执行方法有:
1.execute,返回bool类型
一般不使用,因为其主要用于DDL语句,这一步骤一般在数据库管理工具中完成。
2.executeUpdate(sql),返回受SQL语句执行影响的函数。
一般用于INSERT,UPDATE或DELETE语句
3.executeQuery(sql),返回一个resultSet对象,
一般用于select语句
6.释放资源
finally {
try {
if(resultSet != null){
resultSet.close();
}
if (preparedStatement != null){
preparedStatement.close();
}
if(connection != null){
connection.close();
}
} catch (SQLException throwables) {
throwables.printStackTrace();
}
}
execute,executeQuery,executeUpdate的区别是什么?
- boolean execute(String SQL):如果可以检索到ResultSet对象,则返回一个布尔值true; 否则返回false。使用此方法执行SQL DDL语句或需要使用真正的动态SQL时。
- int executeUpdate(String SQL):返回受SQL语句执行影响的行数。使用此方法执行预期会影响多个行的SQL语句,例如INSERT,UPDATE或DELETE语句。
- ResultSet executeQuery(String SQL):返回一个ResultSet对象。当您希望获得结果集时,请使用此方法,就像使用SELECT语句一样。
JDBC的PreparedStatement是什么?
PreparedStatement的接口扩展了Statement接口,它为您提供了一个通用的Statement对象有两个优点附加功能。
作用:1预编译,效率高 2 安全,避免SQL注入
此语句使您可以动态地提供参数。