IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> JDBC事务操作和完整登陆、注册案例 -> 正文阅读

[大数据]JDBC事务操作和完整登陆、注册案例

一、什么是事务?

在人员管理系统中,你删除一个人员,你即需要删除人员的基本资料,也要删除和该人员相关的信息,如信箱,文章等等,这样,这些数据库操作语句就构成一个事务!

二、事务是必须满足4个条件(ACID)

事务的原子性( Atomicity):一组事务,要么成功;要么撤回。
一致性 (Consistency):事务执行后,数据库状态与其他业务规则保持一致。如转账业务,无论事务执行成功否,参与转账的两个账号余额之和应该是不变的。
隔离性(Isolation):事务独立运行。一个事务处理后的结果,影响了其他事务,那么其他事务会撤回。事务的100%隔离,需要牺牲速度。
持久性(Durability):软、硬件崩溃后,InnoDB数据表驱动会利用日志文件重构修改。可靠性和高速度不可兼得, innodb_flush_log_at_trx_commit 选项 决定什么时候吧事务保存到日志里。

三、Connection的三个方法与事务有关:

setAutoCommit(boolean):设置是否为自动提交事务,如果true(默认值为true)表示自动提交,也就是每条执行的SQL语句都是一个单独的事务,如果设置为false,那么相当于开启了事务了;con.setAutoCommit(false) 表示手动开启事务。
commit():提交结束事务。
rollback():回滚结束事务。

四、事务示例


  • 在这里插入图片描述
  • 代码
 public static  void tranc(){
        Connection conn=null;
        PreparedStatement pst=null;
        try {
             conn = JdbcUtil.getConnection();
//             conn.setAutoCommit(true);//默认自动提交事务
            /*1.手动开启事务*/
            conn.setAutoCommit(false);
            //第一个sql语句
            String sql1="update account set money=money-1000 where name='张三'";
             pst = conn.prepareStatement(sql1);
            pst.executeUpdate();
            //第二个sql语句
            String sql2="update1 account set money=money+1000 where name='李四'";
             pst = conn.prepareStatement(sql2);
            pst.executeUpdate();

        }catch (Exception e){
            try {
                /*2.出现异常,回滚事务*/
                conn.rollback();
            }catch (SQLException e1){

            }
            e.printStackTrace();
        }finally {
            try {
                /*3.提交事务*/
                conn.commit();
                JdbcUtil.myClose(conn,pst);
            }catch (SQLException e1){

            }
        }
    }

五、完整登陆、注册案例

 //登陆
    public  void login(String name, String pwd){
        Connection conn= null;
        PreparedStatement pst=null;
        try {
             conn = JdbcUtil.getConnection();
            String sql="select * from user where name=? and password=?";
             pst = conn.prepareStatement(sql);
            //设置参数
            pst.setString(1, name);
            pst.setString(2, pwd);
            ResultSet rs = pst.executeQuery();
            if(rs.next()){
                System.out.println("登陆成功!");
            }else{
                System.out.println("用户名或者密码错误!");
            }
        }catch (Exception e){
            JdbcUtil.myClose(conn,pst);
        }
    }
    //注册
    Connection conn = JdbcUtil.getConnection();
    public void register(String name,String password){
        PreparedStatement pst=null;
        try {
            boolean flag = nameExists(name);
            if(flag){//用户存在,不允许注册
                return;
            }else{//用户不存在
                String sql="insert into user(name,password) values (?,?)";
                 pst = conn.prepareStatement(sql);
                pst.setString(1, name);
                pst.setString(2, password);
                int i = pst.executeUpdate();
                if(i>0){
                    System.out.println("注册成功!");
                }
            }
        }catch (Exception e){

        }finally {
            JdbcUtil.myClose(conn, pst);
        }
    }
    /*判断注册的用户名是否存在*/
    public boolean nameExists(String name){
        try {
            String sql="select * from user where name=?";
            PreparedStatement pst = conn.prepareStatement(sql);
            pst.setString(1, name);
            ResultSet rs = pst.executeQuery();
            if(rs.next()){//用户名存在
                System.out.println("用户名已经存在,不允许在注册!");
                return true;
            }
        }catch (Exception e){

        }
        return false;
    }
  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2022-04-01 00:08:39  更:2022-04-01 00:10:40 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/16 14:44:50-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码