sql用什么语句实现回滚

生活 2019-04-21 23:56:12 5000

本文收集整理关于sql用什么语句实现回滚的相关议题,使用内容导航快速到达。

内容导航:

  • Q1:sql 回滚语句
  • Q2:sql语句中用什么语句实现事务的回滚
  • Q3:SQL语言中,用于事务回滚的语句是什么?
  • Q4:帮忙写一个SQL 删除语句的事物 实现回滚
  • Q1:sql 回滚语句

    这种情况的数据恢复只能利用事务日志的备份来进行,所以如果你的SQL没有进行相应的全库备份
    或不能备份日志(truncate log on checkpoint选项为1),那么就无法进行数据的恢复了,或者
    只能恢复到最近一次的备份的数据了。
    以下简单说明恢复数据方法:
    1,如果误操作之前存在一个全库备份(或已有多个差异备份或增量备份),首先要做的事就是进
    进行一次日志备份(如果为了不让日志文件变大而置trunc. log on chkpt.选项为1那你就死翘了)
    backup log dbName to disk=fileName
    2,恢复一个全库备份,注意需要使用with norecovery,如果还有其他差异或增量备份,则逐个恢

    restore database dbName from disk=fileName with norecovery
    3,恢复最后一个日志备份即刚做的日志备份,指定恢复时间点到误操作之前的时刻
    restore log dbName from disk=fileName
    with stopat=date_time
    以上这些操作都可以在SQL SERVER企业管理器里完成,难度不大。。。
    当然,如果误操作是一些不记日志的操作比如truncate table,select into等操作,那么是无法利
    用上述方法来恢复数据的...

    Q2:sql语句中用什么语句实现事务的回滚

    -开启事务 begin tran --执行操作 update Accounts_UsersExp set TelPhone=123456 where userid=14 --执行错误事务回滚 rollback --如果正确进行事务提交 commit

    Q3:SQL语言中,用于事务回滚的语句是什么?

    rollback

    Q4:帮忙写一个SQL 删除语句的事物 实现回滚

    这样就可以的。try{ . . . conn=DriverManager.getConnection("..."); //链接数据库 conn.setAutoCommit(false);//禁止自动提交事务 stmt = conn.Create.... String sql1 = "update useraccount set monery=monery-1000 where name=usename"; String sql2 = "update sysaccount set monery=monery+1000 where name=sysname"; stmt=conn.createStatement(); stmt.executeUpdate(sql1); stmt.executeUpdate(sql2); conn.commit(); //统一提交。 }catch(SQLException e){ conn.rollback(); //倘若其中一项sql操作失败,就不会执行commit()方法,而是产生相应的sqlexception,此时就可以捕获 异常代码块中调用rollback()方法撤消事务。 e.printStackTrace(); } finally{ if(stmt!=null){ stmt.close(); } if(conn!=null){ stmt.close(); } }

    相关文章
    新的一天开始精美语句2018-09-05
    for循环语句的嵌套2019-02-08
    创建数据库的sql语句2019-02-19
    c语言的语句以什么结束2019-03-17
    sql语句有函数怎么办2019-03-18
    使用什么语句可以删除数据库2019-04-06
    循环控制语句有哪些2019-06-15
    用switch语句编写分段函数2019-06-18
    选择结构一定含有if语句2019-07-11
    以下语句的输出结果是2019-10-03