上次ID未检测到

时间:2016-04-26 06:00:34

标签: mysql sql

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

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 ;

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

2 个答案:

答案 0 :(得分:1)

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

答案 1 :(得分:0)

CREATE TRIGGER `test` 
BEFORE UPDATE ON `tbl_a`
FOR EACH ROW 
INSERT INTO tbl_b_bckup(a_id,name,villa)
VALUES (OLD.id,OLD.name,OLD.villa)

无需从tbl_a中选择行。您已将其置于别名OLD已知的伪行中。