zoukankan      html  css  js  c++  java
  • SQL执行并返回执行前/后结果

    SQLServer:

    1、插入数据,并返回插入的数据:
    INSERT INTO TestTB(Province,City) output inserted.Province, inserted.City VALUES('广东','深圳')

    2、同理,删除数据也是一样的,只不过是使用deleted表罢了。
    delete from TestTB output deleted.* where id=1

    3、两个结合一起:返回更新前和更新后的数据:
    UPDATE TestTB SET Province = '湖南',City='郴州' OUTPUT '我来自(更新前)'+ DELETED.Province+DELETED.City as [Before] ,'我来自(更新后)' + Inserted.Province+Inserted.City as [After] WHERE id=1

    4、还可以将返回的结果保存在表变量中,这在删除数据,并把删除的数据插入到历史表时很实用
    DECLARE @temp TableTABLE(    idint,    Provincevarchar(50),    Cityvarchar(50) )DELETEFROMTestTB OUTPUT deleted.*INTO@tempTableWHEREid>4SELECT*FROM@tempTable
    -- 返回更新前的值
    UPDATE xxx.dbo.xxx SET suffix=suffix+2  OUTPUT Inserted.suffix WHERE prefix='ABC'
    -- 返回更新后的值
    UPDATE xxx.dbo.xxx SET suffix=suffix+2  OUTPUT DELETED.suffix WHERE prefix='ABC'
     

    MySql:

    在mybatis的xml的insert语句上加上:

    <insert id="insertSelective" parameterType="xxx.xxx.xxxEntity" useGeneratedKeys="true" keyProperty="id">

    传入model调insertSelective接口后,id可通过model取到。

  • 相关阅读:
    html 页面打印元素被切割,元素自适应分页
    linux jupyter 安装
    == 与 equals()的区别
    多段图
    数据仓库和ODS 的并行
    Linux下对sh文件的基本操作总结
    linux tr命令详解
    数据仓库分层
    利用SQOOP将数据从数据库导入到HDFS(并行导入,增量导入)
    Etl之HiveSql调优(left join where的位置)
  • 原文地址:https://www.cnblogs.com/mr-yang-localhost/p/6683297.html
Copyright © 2011-2022 走看看