Java中JDBC如何使用
导读:本文共7673字符,通常情况下阅读需要26分钟。同时您也可以点击右侧朗读,来听本文内容。按键盘←(左) →(右) 方向键可以翻页。
摘要: 概念Java DataBase Connectivity Java 数据库连接, Java语言操作数据库 JDBC本质:其实是官方(sun公司)定义的一套操作所有关系型数据库的规则,即接口。各个数据库厂商去实现这套接口,提供数据库驱动jar包。我们可以使用这套接口(JDBC)编程,真正执行的代码是驱动jar包中的实现类。快速入门步骤1.导入驱动jar包<!... ...
目录
(为您整理了一些要点),点击可以直达。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如何使用的详细内容,希望对您有所帮助,信息来源于网络。