MariaDB更新错误内连接并选择

时间:2013-12-16 10:22:20

标签: mysql sql-update inner-join mariadb iban

我希望你能再次帮助我,谢谢你指出我正确的方向,为德国的新IBAN创建校验位。我现在正尝试使用新计算的BIC和IBAN更新我们的成员资格数据库,但似乎在MariaDB MySQL数据库上的UPDATE语句有问题,尽管我认为我的语法正确。

我要做的就是在SELECT语句的表“mitglieder”中设置两个字段“konto_bic”和“konto_iban”,它创建一个名为b的临时表,其中包含列“id”,“bic”和“ IBAN”。 “id”在两个表中是相同的。

这是我的第一次尝试:

update a
set a.`konto_bic` = b.`BIC`, a.`konto_iban` = b.`IBAN`
from `mitglieder` a
INNER JOIN (SELECT m.`id`, m.`nachname`, m.`vorname`, m.`konto_bank`, m.`konto_blz`, m.`konto_nummer`, k.`bic` AS 'BIC', CONCAT('DE',LPAD(98-MOD(CONVERT(CONCAT(m.`konto_blz`,LPAD(m.`konto_nummer`,10,'0'),'1314','00'), decimal(24)),97),2,'0'),m.`konto_blz`,LPAD(m.`konto_nummer`,10,'0')) AS 'IBAN'
FROM `mitglieder` m
LEFT JOIN `konvert_bic_blz` k
ON m.`konto_blz` = k.`blz`
ORDER BY m.`nachname`, m.`vorname`) b
ON a.`id` = b.`id`

然而,这产生了一个错误,我尝试了这个:

update `mitglieder` a
set a.`konto_bic` = b.`bic`, a.`konto_iban` = b.`iban`
FROM (SELECT m.`id` as 'id', k.`bic` as 'bic', CONCAT('DE',LPAD(98-MOD(CONVERT(CONCAT(m.`konto_blz`,LPAD(m.`konto_nummer`,10,'0'),'1314','00'), decimal(24)),97),2,'0'),m.`konto_blz`,LPAD(m.`konto_nummer`,10,'0')) AS 'iban'
FROM `mitglieder` m
LEFT JOIN `konvert_bic_blz` k
ON m.`konto_blz` = k.`blz`) b
WHERE a.`id` = b.`id`

这也没有让我更进一步(DB的错误)。

任何人都可以看到我的语法错误可能是什么? 提前感谢您的帮助

斯蒂芬

2 个答案:

答案 0 :(得分:2)

尝试以下SQL

UPDATE `mitglieder` a,
       (SELECT m.`id` AS 'id',
               k.`bic` AS 'bic',
               CONCAT('DE',LPAD(98-MOD(CONVERT(CONCAT(m.`konto_blz`,LPAD(m.`konto_nummer`,10,'0'),'1314','00'), decimal(24)),97),2,'0'),m.`konto_blz`,LPAD(m.`konto_nummer`,10,'0')) AS 'iban'
        FROM `mitglieder` m
        LEFT JOIN `konvert_bic_blz` k ON m.`konto_blz` = k.`blz`) b
SET a.`konto_bic` = b.`bic`, a.`konto_iban` = b.`iban`
WHERE a.`id` = b.`id`

更新语法

http://dev.mysql.com/doc/refman/5.0/en/update.html

答案 1 :(得分:1)

我在MariaDB 10.2.6上试过这个:

SET sql_mode = 'ANSI_QUOTES'

UPDATE "test"."user" AS "a"
INNER JOIN "test"."user_profile" AS "c" ON "c".user_id = "a".id
INNER JOIN "test"."profile" AS "d" ON "d".id = "c".profile_id
SET "a".firstname = 'laurent'
WHERE "a".id = 3;

它有效:)