Java中JDBC如何使用(java,jdbc,开发技术)

时间:2024-05-08 08:23:45 作者 : 石家庄SEO 分类 : 开发技术
  • TAG :

    Java%E4%B8%ADJDBC%E5%A6%82%E4%BD%95%E4%BD%BF%E7%94%A8

Java DataBase Connectivity Java 数据库连接, Java语言操作数据库 JDBC本质:其实是官方(sun公司)定义的一套操作所有关系型数据库的规则,即接口。各个数据库厂商去实现这套接口,提供数据库驱动jar包。我们可以使用这套接口(JDBC)编程,真正执行的代码是驱动jar包中的实现类。

1.导入驱动jar包

2.注册驱动

3.获取数据库连接对象 Connection

4.定义sql

5.获取执行sql语句的对象 Statement

6.执行sql,接受返回结果

7.处理结果

8.释放资源

功能:

1.注册驱动:告诉程序该使用哪一个数据库驱动jar

static void registerDriver(Driver driver) :注册与给定的驱动程序 DriverManager 。 写代码使用: Class.forName("com.mysql.jdbc.Driver"); 通过查看源码发现:在com.mysql.jdbc.Driver类中存在静态代码块

注意:mysql5之后的驱动jar包可以省略注册驱动的步骤。

2.获取数据库连接:

方法:static Connection getConnection(String url, String user, String password)

参数:

url:指定连接的路径

语法:jdbc:mysql://ip地址(域名):端口号/数据库名称 例子:jdbc:mysql://localhost:3306/db3 细节:如果连接的是本机mysql服务器,并且mysql服务默认端口是3306,则url可以简写为:jdbc:mysql:///数据库名称

user:用户名

password:密码

功能:

获取执行sql 的对象

Statement createStatement() PreparedStatement prepareStatement(String sql)

管理事务:

开启事务:setAutoCommit(boolean autoCommit) :调用该方法设置参数为false,即开启事务 提交事务:commit() 回滚事务:rollback()

1.执行sql

boolean execute(String sql) :可以执行任意的sql 了解 int executeUpdate(String sql) :执行DML(insert、update、delete)语句、DDL(create,alter、drop)语句 返回值:影响的行数,可以通过这个影响的行数判断DML语句是否执行成功 返回值>0的则执行成功,反之,则失败。 ResultSet executeQuery(String sql) :执行DQL(select)语句

2.练习:

account表 添加一条记录

account表 修改记录

account表 删除一条记录

代码:

boolean next(): 游标向下移动一行,判断当前行是否是最后一行末尾(是否有数据),如果是,则返回false,如果不是则返回true getXxx(参数):获取数据 Xxx:代表数据类型 如: int getInt() , String getString() 参数:

int:代表列的编号,从1开始 如: getString(1)

String:代表列名称。 如: getDouble("balance")

注意: 使用步骤:

游标向下移动一行

判断是否有数据

获取数据

SQL注入问题:在拼接sql时,有一些sql的特殊关键字参与字符串的拼接。会造成安全性问题

输入用户随便,输入密码:a' or 'a' = 'a

sql:select from user where username = 'fhdsjkf' and password = 'a' or 'a' = 'a'

解决sql注入问题:使用PreparedStatement对象来解决

预编译的SQL:参数使用?作为占位符

步骤:

导入驱动jar包 mysql-connector-java-5.1.37-bin.jar

注册驱动

获取数据库连接对象 Connection

定义sql

注意:sql的参数使用?作为占位符。 如:select from user where username = ? and password = ?;

获取执行sql语句的对象 PreparedStatement Connection.prepareStatement(String sql)

给?赋值:

方法: setXxx(参数1,参数2) 参数1:?的位置编号 从1 开始 参数2:?的值

执行sql,接受返回结果,不需要传递sql语句

处理结果

释放资源

注意:后期都会使用PreparedStatement来完成增删改查的所有操作

可以防止SQL注入

效率更高

目的:简化书写

1.注册驱动也抽取

2.抽取一个方法获取连接对象

需求:不想传递参数(麻烦),还得保证工具类的通用性。 解决:配置文件jdbc.properties

url=
user=
password=

3.抽取一个方法释放资源

需求

通过键盘录入用户名和密码

判断用户是否登录成功

select from user where username = "" and password = ""; 如果这个sql有查询结果,则成功,反之,则失败

步骤

1.创建数据库表 user

2.代码实现

一个包含多个步骤的业务操作。如果这个业务操作被事务管理,则这多个步骤要么同时成功,要么同时失败。

开启事务

提交事务

回滚事务

开启事务:setAutoCommit(boolean autoCommit) :调用该方法设置参数为false,即开启事务 在执行sql之前开启事务 提交事务:commit() 当所有sql都执行完提交事务 回滚事务:rollback() 在catch中回滚事务

本文:Java中JDBC如何使用的详细内容,希望对您有所帮助,信息来源于网络。
上一篇:Java如何实现简单邮件发送功能下一篇:

29 人围观 / 0 条评论 ↓快速评论↓

(必须)

(必须,保密)

阿狸1 阿狸2 阿狸3 阿狸4 阿狸5 阿狸6 阿狸7 阿狸8 阿狸9 阿狸10 阿狸11 阿狸12 阿狸13 阿狸14 阿狸15 阿狸16 阿狸17 阿狸18