首页
学习
活动
专区
圈层
工具
发布

select from update row的实现

DTCC大会上,阿里江疑的演讲中提到一个:select from update hot row; 不明白如何在Oracle中实现的,他的意思是在一条SQL中实现update和select这条update...创建测试表: create table tbl_returninto( id number, remark varchar2(5)); SQL> select * from tbl_returninto...插入一条记录,使用returning into在同一条SQL中获得插入的id值: SQL> declare 2 l_id tbl_returninto.id%type; 3 begin...更新和删除一条记录,使用returning into获得更新和删除的id值: SQL> declare l_id tbl_returninto.id%type; 2 begin 3 update...总结: 使用returning into子句可以在一条SQL中将insert、update和delete影响的行记录指定字段信息select出来,其中insert和update都是执行之后的结果,delete

1.8K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    SQL命令 UPDATE(二)

    SQL命令 UPDATE(二) 显示到逻辑数据转换 数据以逻辑模式格式存储。 例如,日期存储为整数天数,时间存储为从午夜开始的秒数,%List存储为编码字符串。...因此,动态SQL不能使用UPDATE或INSERT来设置类型为%List的属性值。...此类型的更新执行%SerialObject属性值的验证。 FROM子句 UPDATE命令可能没有FROM关键字。它可以简单地指定要更新的表(或视图),并使用WHERE子句选择要更新的行。...FROM子句通常(但并非总是)与涉及多个表的WHERE子句一起使用。FROM子句可以很复杂,并且可以包括ANSI联接语法。UPDATE FROM子句允许SELECT FROM子句中支持的任何语法。...此UPDATE FROM子句提供与Transact-SQL的功能兼容性。 以下示例显示如何使用此FROM子句。

    2.4K30

    SQL命令 UPDATE(三)

    SQL命令 UPDATE(三) 参照完整性 如果没有指定%NOCHECK, IRIS将使用系统范围的配置设置来确定是否执行外键引用完整性检查; 默认值是执行外键引用完整性检查。...可以在系统范围内设置此默认值,如外键引用完整性检查中所述。 要确定当前系统范围的设置,调用$SYSTEM.SQL.CurrentSettings()。...如果任何指定的行不能更新,则不更新指定的行,数据库将恢复到发出UPDATE之前的状态。 可以通过调用SET TRANSACTION %COMMITMODE来修改SQL中当前进程的这个默认值。...传统SQL锁升级:类不使用“E”类型锁升级的最可能的原因是存在一个多属性IDKey索引。 在本例中,每个%Save都会增加锁计数器的值。...对于这两种锁升级策略,可以使用$SYSTEM.SQL.Util.GetOption(“LockThreshold”)方法确定当前系统范围的锁阈值。 默认值是1000。

    2.2K20

    sql-update 用法

    update 表示更新,要想更新数据库的某条数据,我们通常用: update {表名} set {列名}={新的值} where {条件} Jetbrains全家桶1年46,售后保障稳定...以LeetCode上看到的一个简单的题目为例: 问题1: 将A的薪水修改为8000; 答案: update Salary set salary where name = A; 问题2...: 交换所有的 ‘f’ 和 ‘m’ (即,将所有 ‘f’ 变为 ‘m’ ,反之亦然),仅使用 单个 update 语句 ,且不产生中间临时表。...答案: # 解法一: update Salary set sex = ( case when sex='m' then 'f' else 'm' end # 如果sex='m'为真,更新为f,...如果为假,则更新为'm' ) # 解法二: update Salary set sex = if('m','f','m' ) # 意思与解法一类似 版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人

    64810

    MySQL insert or update sql

    MySQL 一条 sql 实现数据保存变更 insert or update ,如果没有执行insert,有就update 需要 有主键 PRIMARY 或 唯一索引 UNIQUE MySQL...中的INSERT … ON DUPLICATE KEY UPDATE语句,该语句是基于唯一索引或主键使用 ON DUPLICATE KEY UPDATE后面可以放多个字段,用英文逗号分割。...使用ON DUPLICATE KEY UPDATE,最终如果插入了一个新行,则受影响的行数是1,如果修改了已存在的一行数据,则受影响的行数是2,如果值不变,则受影响行数是0。...'wx8c6e61e00505878e','ozt9K0ykJJnLp-oASEl7ly_BKj7w','奈何',1,1,5,4,60,NOW(),300 ) ON DUPLICATE KEY UPDATE...INSERT… ON DUPLICATE KEY UPDATE on a table with more than one UNIQUE KEY is unsafe 翻译:使用BINLOG_FORMAT

    3.6K20

    SQL 中的 NULL 值:定义、测试和处理空数据,以及 SQL UPDATE 语句的使用

    SQL NULL 值 什么是 NULL 值? NULL 值是指字段没有值的情况。如果表中的字段是可选的,那么可以插入新记录或更新记录而不向该字段添加值。此时,该字段将保存为 NULL 值。...以下 SQL 列出了所有具有 "Address" 字段中 NULL 值的客户: SELECT CustomerName, ContactName, Address FROM Customers WHERE...以下 SQL 列出了所有具有 "Address" 字段中有值的客户: SELECT CustomerName, ContactName, Address FROM Customers WHERE Address...使用 IS NULL 和 IS NOT NULL 运算符可以有效地处理数据库中的空值情况。 SQL UPDATE 语句 UPDATE 语句用于修改表中的现有记录。...UPDATE 语法 UPDATE 表名 SET 列1 = 值1, 列2 = 值2, ... WHERE 条件; 注意:在更新表中的记录时要小心!请注意UPDATE语句中的WHERE子句。

    2.4K20

    SQL命令 FROM(一)

    SQL命令 FROM(一) 一个SELECT子句,指定要查询的一个或多个表。 大纲 SELECT ......表连接 当在FROM子句中指定多个表名时, SQL将对这些表执行连接操作。 执行的连接类型由每对表名之间的连接关键字短语或符号指定。 当两个表名用逗号分隔时,将执行交叉连接。...因此, SQL在FROM子句中提供了OPTIMIZE-OPTION关键字。可以按任意顺序指定多个优化关键字,并以空格分隔。...%NOFLATTEN 此可选关键字在量化的子查询(返回布尔值的子查询)的FROM子句中指定。它指定编译器优化器应抑制子查询展平。...它通过用满足条件的数据值填充临时索引来实现这一点。 IRIS不是重复执行子查询,而是在临时索引中查找这些值。

    2.8K40

    BI-SQL丨UPDATE

    [1240] UPDATE语句 UPDATE语句在SQL的查询中,通常可以用来修改表中的数据,即我们经常听说的“改”。...可能对于一些SQL的大佬们来说,这个是一个常识性的知识,但是对于类似白茶这类的SQL小白来说,往往这些不起眼的常识性知识才是我们需要注意的雷区。...基础语法 UPDATE 表名称 SET 列名称 = 新值 WHERE 列名称 = 条件值 使用实例 案例数据: [1240] 在白茶本机的数据库中,存在名为“TEST”的数据库,存在名为“产品表”的案例数据...例子1: 在SQL查询中,将商品分类条件值为“婴儿类”的字段替换为“白茶类”。...UPDATE 产品表 SET [商品分类] = N'白茶类' WHERE [商品分类] = N'婴儿类' [1240] 结果如下: [1240] 例子2: 在PowerBI中,将商品分类条件值为“白茶类

    60400

    聊聊sql的并发update

    序 本文主要简述一下不同sql语句并发update的情况。 指定主键update update tableA set owner = ? where id = ?...这种带有版本号或时间戳的,属于乐观锁方案,并发执行的sql,最先到的执行完之后,版本号发生变化,同一时刻并发的同版本号的update语句由于版本号对不上则无法udpate成功 指定主键及与更新字段相关的条件...先到的sql先执行,而且owner发生变化,安排到后执行的sql,由于owner发生变化,则未能执行成功 更新值与原值相关 update tableA set totalNum = totalNum +...相当于如下: 1) open a transaction 2) fetch the data (SELECT totalNum FROM tableA WHERE id = ?...MYSQL-Innodb下,update的并发是否会产生脏数据? SQL处理并发之乐观锁

    1.4K10

    SQL语句规范参考

    公司有SQL语句规范的参考,这里特别做个笔记。 书写风格 1. 语句关键字应全部使用小写。 2. 引用字符时应使用单引号。如:update testable set idcol=’abcd’。 3....--被视为SQL的注释,结果语句报错。 4. 不得使用“select * from …”语法,必须标明字段名。即select col1, col2,… from tablea where … 5....SQL语句包含多表连接时,必须加上表的别名,对每个字段的使用都要带上表别名。...一条SQL语句中不宜使用3层以上的嵌套查询。如果超过,则应在Java等应用服务器程序中处理。 5. 一条SQL语句中不得从4个及以上表中同时取数。...Select into是SQL Server特有语法,因为Oracle和DB2不支持。 9. 应将Null值与空字符串(长度为零的字符串)视为不同。

    1.6K20
    领券