JDBC(一)

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注入

此语句使您可以动态地提供参数。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值