当前列是 VARCHAR(255) NOT NULL,那么如何将其更改为 TEXT NOT NULL?
注意:要更改其属性类型的列是另一列的 UNIQUE KEY 组合。例如
唯一键(名称、描述)
列描述当前位于 varchar(255) 中。无法更改,原因如下:
ERROR 1170 (42000): BLOB/TEXT 列“描述”在没有密钥长度的密钥规范中使用
我需要它是文本,否则我需要重新创建整个东西?我已经得到了一些乏味而重要的数据。重新创建会很麻烦。
当前列是 VARCHAR(255) NOT NULL,那么如何将其更改为 TEXT NOT NULL?
注意:要更改其属性类型的列是另一列的 UNIQUE KEY 组合。例如
唯一键(名称、描述)
列描述当前位于 varchar(255) 中。无法更改,原因如下:
ERROR 1170 (42000): BLOB/TEXT 列“描述”在没有密钥长度的密钥规范中使用
我需要它是文本,否则我需要重新创建整个东西?我已经得到了一些乏味而重要的数据。重新创建会很麻烦。
你打算使用 TEXT 列作为 UNIQUE KEY 的一部分吗?这是非常低效的!不要那样做!我强烈建议你:
'description_hash' char(32) not null default ''
description
到其中。例如。description_hash=MD5(description)
UNIQUE KEY (name, description_hash)
当然,您需要 description_hash
在您的代码中保持列是最新的,但正如所见 - 在大多数情况下,它只需要很少的代码更改。或者您可以使用触发器来处理此问题。
我有完全相同的问题。
我添加了一个新的 char(32) 列(我调用它hash
并在其上添加了唯一索引)和两个触发器。
delimiter |
CREATE TRIGGER insert_set_hash
BEFORE INSERT ON my_table_name
FOR EACH ROW BEGIN
SET NEW.hash = MD5(NEW.my_text);
END; |
CREATE TRIGGER update_set_hash
BEFORE UPDATE ON my_table_name
FOR EACH ROW BEGIN
SET NEW.hash = MD5(NEW.my_text);
END; |
delimiter ;
通过使用触发器并在散列上添加唯一索引,您可以确保散列值始终是最新的和唯一的。
alter table your_table
modify column your_column text not null;
对于唯一键
alter table your_table
add unique index your_index_name (your_column(your_length));
your_length
= 最多允许 1000 个字节
最大密钥长度为 1000 字节。这也可以通过更改源并重新编译来更改。对于长度超过 250 字节的密钥,使用比默认值 1024 字节更大的密钥块大小
两者的长度(描述+另一列不能超过1000),所以
alter table your_table
add unique index your_index_name (description(800), another_column(200));