gpt4 book ai didi

mysql - 未检测到最后一个 ID

转载 作者:行者123 更新时间:2023-11-29 11:34:22 25 4
gpt4 key购买 nike

我正在尝试创建一个触发器。就像这样

CREATE TABLE IF NOT EXISTS `tbl_a` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`name` varchar(30) NOT NULL,
`villa` varchar(30) NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1 AUTO_INCREMENT=2 ;

--
-- Dumping data for table `tbl_a`
--

INSERT INTO `tbl_a` (`id`, `name`, `villa`) VALUES
(1, 'KAKUL', 'ASHOK NAGER');

--
-- Triggers `tbl_a`
--
DROP TRIGGER IF EXISTS `test`;
DELIMITER //
CREATE TRIGGER `test` BEFORE UPDATE ON `tbl_a`
FOR EACH ROW INSERT INTO tbl_b_bckup(a_id,name,villa) SELECT (id,name,villa) FROM tbl_a WHERE id = @id
//
DELIMITER ;

-- --------------------------------------------------------

--
-- Table structure for table `tbl_b_bckup`
--

CREATE TABLE IF NOT EXISTS `tbl_b_bckup` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`a_id` int(11) NOT NULL,
`name` varchar(30) NOT NULL,
`villa` varchar(30) NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1 AUTO_INCREMENT=1 ;

如果我用 no 替换 @id ,它的作品但是 .我需要最后更新的 rows_id 。我怎么才能得到它?我希望在更新 tbl_a 上的任何内容之前。将在 tbl_b_backup 上创建备份行。这个查询甚至不允许我编辑 tbl_a

最佳答案

使用 OLD.id 获取旧列值的引用,使用 NEW.id 获取新列值的引用

关于mysql - 未检测到最后一个 ID,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36856399/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com