本篇内容介绍了“Java操作数据库的方法是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
在本次事务的执行过程当中,我们指定的记录被查询,在我查询的过程当中记录就会被锁定,任何人,任何事务都不能对我指定查询数据进行修改操作(不能改,但是可以看),直到我都查询结束。
//sql指令
String sql = "select * from t_shuihuo where id < ? for update ";
package com.luosf.jdbc;
import com.luosf.jdbc.utils.JdbcUtil;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
/**
* JDBC中锁的使用
* for updata
*/
public class JdbcLock {
public static void main(String[] args) {
Connection conn = null;
PreparedStatement stat = null;
ResultSet res = null;
try {
//创建驱动
//获取数据库对象
conn = JdbcUtil.getConnection();
//sql指令
String sql = "select * from t_shuihuo where id < ? for update ";
conn.setAutoCommit(false);//开启事务
//3,sql语句进行编译
stat = conn.prepareStatement(sql);
//给占位符填充值
//JDBC下标从1开始的
stat.setInt(1,16); //1,代表第一个问号
Thread.sleep(1000*10); //模拟访问时间
//4,执行sql
res = stat.executeQuery();
//5,处理查询结果集
while (res.next()){
int id = res.getInt("id");
String name = res.getString("name");
String nickname = res.getString("nickname");
System.out.println("id :"+ id + " name :" +name + " 昵称 :"+nickname);
}
conn.commit();//提交事务
} catch (SQLException throwables) {
try {
if (conn != null){
conn.rollback(); //回滚事务
}
} catch (SQLException e) {
e.printStackTrace();
}
throwables.printStackTrace();
} catch (InterruptedException e) {
e.printStackTrace();
} finally{
//释放资源
JdbcUtil.close(conn,stat,res);
}
}
}
package com.luosf.jdbc;
import com.luosf.jdbc.utils.JdbcUtil;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.SQLException;
/**
* 检测锁
*/
public class JdbcLockTest {
public static void main(String[] args) {
Connection conn = null;
PreparedStatement stat = null;
try {
//获取驱动
//获取数据库链接对象
conn = JdbcUtil.getConnection();
//开启事务
conn.setAutoCommit(false);
//锁开始后进行修改数据
String sql = "update t_shuihuo set name = '小罗' where id = ? ";
stat = conn.prepareStatement(sql);
stat.setInt(1,10); //1,代表第一个问号
int cunt = stat.executeUpdate();
System.out.println("更新了"+cunt+"条数据");
conn.commit();//提交事务
} catch (SQLException throwables) {
try {
if (conn != null){
conn.rollback();
}
} catch (SQLException e) {
e.printStackTrace();
}
throwables.printStackTrace();
} finally {
//释放资源
JdbcUtil.close(conn,stat,null);
}
}
}
需要等锁等待时间完成才能进行修改
“Java操作数据库的方法是什么”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注亿速云网站,小编将为大家输出更多高质量的实用文章!
亿速云「云数据库 MySQL」免部署即开即用,比自行安装部署数据库高出1倍以上的性能,双节点冗余防止单节点故障,数据自动定期备份随时恢复。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。