温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

Java操作数据库的方法是什么

发布时间:2021-12-15 13:33:06 来源:亿速云 阅读:151 作者:iii 栏目:开发技术

本篇内容介绍了“Java操作数据库的方法是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

一、悲观锁(也叫行级锁)

在本次事务的执行过程当中,我们指定的记录被查询,在我查询的过程当中记录就会被锁定,任何人,任何事务都不能对我指定查询数据进行修改操作(不能改,但是可以看),直到我都查询结束。

1.使用悲观锁(在事务中的sql语句中使用)

//sql指令
            String sql = "select * from  t_shuihuo where id < ? for update ";

2..完整代码

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);
        }
    }
}

3..测试代码

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操作数据库的方法是什么

“Java操作数据库的方法是什么”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注亿速云网站,小编将为大家输出更多高质量的实用文章!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI