像在 SQL 中一样插入 GENERATED ALWAYS

肉山梅塔

我创建了一个这样的表:

CREATE TABLE `group` (
  `g_id` int(10) unsigned NOT NULL AUTO_INCREMENT,
  `owner_id` int(10) unsigned NOT NULL,
  `g_name` varchar(45) NOT NULL,
  `refer_code` varchar(45) GENERATED ALWAYS AS (concat(`g_name`)) VIRTUAL,
  `created_on` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP,
  `row_hash` varchar(256) NOT NULL,
  PRIMARY KEY (`g_id`),
  UNIQUE KEY `g_hash_UNIQUE` (`row_hash`),
  UNIQUE KEY `refer_UNIQUE` (`refer_code`),
  KEY `owner_idx` (`owner_id`),
  CONSTRAINT `owner_id` FOREIGN KEY (`owner_id`) REFERENCES `user` (`u_id`) ON DELETE CASCADE ON UPDATE CASCADE
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

更新语句给了我错误:

INSERT INTO `server`.`group` (`owner_id`, `g_name`, `refer_code`, `created_on`, `row_hash`) 
VALUES ('4', 'cool', null, '2018-02-13 10:34:11', '452345324')

错误代码:3105。不允许为表 'group' 中生成的列 'refer_code' 指定的值。

如何指定refer_codewhile插入?

拉西尔·希兰

生成的列的值是根据您的 列定义中的表达式计算得出的CREATE TABLE,因此不要将其包含在INSERTorUPDATE语句中:

INSERT INTO `server`.`group` (`owner_id`, `g_name`, `created_on`, `row_hash`) 
VALUES ('4', 'cool', '2018-02-13 10:34:11', '452345324')

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章