基本上,以下是我想要做的:
INSERT INTO table
(
column1, column2
)
VALUES
(
?, ?
)
WHERE EXISTS
(
SELECT 1
FROM table2
WHERE id = ?
)
换句话说:如果 table2 中存在 id,则应该插入值,否则不会发生任何事情。
此任务的正确语法是什么?
我发现这可以满足我的需要。
INSERT INTO table1
(
column1, column2
)
SELECT ?, ?
FROM
table2
WHERE EXISTS
(
SELECT 1
FROM table2
WHERE id = ?
)
LIMIT 1
我没有可用的 mysql 数据库,但与其他数据库类似,阅读参考资料后,它必须类似于
INSERT INTO table (column1, column2)
SELECT ?, ? FROM table2 WHERE id=?
我知道这是一个已经回答的非常古老的问题,但是我的一个朋友帮助建立了一个带有“约束”的数据库,其中插入或更新必须有 1 个值与来自同一数据库中不同表的一个值完全匹配为了开火。
我对 MySQL 调用不是很好,所以我不明白它到底做了什么……但它可以帮助你减少做你想做的事所需的代码?(注意:我不得不对其进行一些修改以从中删除一些敏感名称等,但它应该是一个很好的表示。)
-- -----------------------------------------------------
-- Table `db1`.`table1`
-- -----------------------------------------------------
CREATE TABLE IF NOT EXISTS `db1`.`table1` (
`id` INT NOT NULL AUTO_INCREMENT ,
`av_key` VARCHAR(40) NOT NULL ,
PRIMARY KEY (`id`) )
ENGINE = InnoDB;
-- -----------------------------------------------------
-- Table `db1`.`table2`
-- -----------------------------------------------------
CREATE TABLE IF NOT EXISTS `db1`.`table2` (
`bkid` INT NOT NULL AUTO_INCREMENT ,
`id` INT NOT NULL ,
`data` VARCHAR(6144) NULL ,
PRIMARY KEY (`bkid`) ,
INDEX `id_idx` (`id` ASC) ,
CONSTRAINT `id`
FOREIGN KEY (`id` )
REFERENCES `db1`.`table1` (`id` )
ON DELETE NO ACTION
ON UPDATE NO ACTION)
ENGINE = InnoDB;
有了这个,你只需要执行插入/更新语句,如果两个表中的“id”都不匹配,它就会失败。
不知道您是否已经发现或者这是否是您需要的,但认为值得分享!