Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/mysql/72.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
将Mysql转换为Oracle很奇怪_Mysql_Oracle - Fatal编程技术网

将Mysql转换为Oracle很奇怪

将Mysql转换为Oracle很奇怪,mysql,oracle,Mysql,Oracle,这是mysql代码 UPDATE ORDER_ITEM OI INNER JOIN ORDER_PAYMENT OP ON OI.ORDER_PAYMENT_ID = OP.ORDER_PAYMENT_ID SET OI.ORDER_STATUS = '10', OI.PAY_DATE = '20150101', OP.PAY_DATE = '20150101' WHERE OI.ORDER_STATUS = '0' AND OP.

这是mysql代码

UPDATE ORDER_ITEM OI
INNER JOIN ORDER_PAYMENT OP
ON OI.ORDER_PAYMENT_ID = OP.ORDER_PAYMENT_ID
SET OI.ORDER_STATUS    = '10',
  OI.PAY_DATE          = '20150101',
  OP.PAY_DATE          = '20150101'
WHERE OI.ORDER_STATUS        = '0'
AND OP.AMOUNT                = 3333
AND OP.REMAINING_AMOUNT      = 0
AND OP.ORDER_PAYMENT_ID      = 9999 
转换Oracle错误=>ORA-00971:缺少SET关键字

我想知道如何将此语句转换为Oracle


另外,Oracle中提供的多表更新?

Oracle肯定不允许在一条SQL语句中更新两个表。因此,您的案例需要3个陈述:

-- This query locks target rows in both tables.
-- It's required to be sure that rows wasn't changed in other sessions
-- between the first and second UPDATE statements
SELECT *
  FROM order_item oi
 INNER JOIN order_payment op
    ON oi.order_payment_id = op.order_payment_id    
 WHERE oi.order_status = '0'
   AND op.amount = 3333
   AND op.remaining_amount = 0
   AND op.order_payment_id = 9999
   FOR UPDATE NOWAIT

-- first update
UPDATE order_item
   SET order_status = '10',
       pay_date = '20150101'
 WHERE rowid IN (SELECT oi.rowid
                      FROM order_item oi
                     INNER JOIN order_payment op
                        ON oi.order_payment_id = op.order_payment_id                                
                     WHERE oi.order_status = '0'
                       AND op.amount = 3333
                       AND op.remaining_amount = 0
                       AND op.order_payment_id = 9999);

--second update
UPDATE order_payment
   SET pay_date = '20150101'
 WHERE rowid IN (SELECT op.rowid
                      FROM order_item oi
                     INNER JOIN order_payment op
                        ON oi.order_payment_id = op.order_payment_id                                
                     WHERE oi.order_status = '0'
                       AND op.amount = 3333
                       AND op.remaining_amount = 0
                       AND op.order_payment_id = 9999);
使用PL/SQL,我们可以稍微简化这段代码,但我们仍然必须编写一个SELECT FOR UPDATE,并为每个连接的表编写一个更新