0

基本上,以下是我想要做的:

INSERT INTO table
(
    column1, column2
)
VALUES
(
    ?, ?
)
WHERE EXISTS
(
    SELECT 1
    FROM table2
    WHERE id = ?
)

换句话说:如果 table2 中存在 id,则应该插入值,否则不会发生任何事情。

此任务的正确语法是什么?

4

3 回答 3

2

我发现这可以满足我的需要。

INSERT INTO table1
(
    column1, column2
)
SELECT ?, ?
FROM
table2
WHERE EXISTS
(
    SELECT 1
    FROM table2
    WHERE id = ?
)
LIMIT 1
于 2013-09-07T20:40:01.357 回答
2

我没有可用的 mysql 数据库,但与其他数据库类似,阅读参考资料后,它必须类似于

INSERT INTO table (column1, column2)
    SELECT ?, ? FROM table2 WHERE id=?
于 2013-09-07T20:47:39.687 回答
0

我知道这是一个已经回答的非常古老的问题,但是我的一个朋友帮助建立了一个带有“约束”的数据库,其中插入或更新必须有 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”都不匹配,它就会失败。

不知道您是否已经发现或者这是否是您需要的,但认为值得分享!

于 2014-04-27T15:36:59.963 回答