簡體   English   中英

像在SQL中一樣插入GENERATED ALWAYS

[英]Insert GENERATED ALWAYS as in SQL

我創建了一個這樣的表:

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。不允許為表“組”中的已生成列“ refer_code”指定值。

插入時如何指定refer_code

生成的列的值是根據CREATE TABLE的列定義中的表達式計算得出的,因此請勿將其包括在INSERTUPDATE語句中:

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

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM