MySQL:如何将varchar(255)UNIQUE列更改为UNIQUE Text NOT NULL?

时间:2011-01-20 07:49:14

标签: mysql sql mysql-error-1170

当前列是VARCHAR(255)NOT NULL,那么如何将其更改为TEXT NOT NULL?

注意:要更改其属性类型的列是另一列的UNIQUE KEY组合。 E.g。

UNIQUE KEY(名称,描述)

列描述当前在varchar(255)中。因此无法改变:

  

ERROR 1170(42000):BLOB / TEXT列'描述'用于没有密钥长度的密钥规范

我需要它是TEXT,否则我需要重新创建整个事情?我已经收到了一些繁琐而重要的数据。重新创建会很麻烦。

3 个答案:

答案 0 :(得分:12)

您打算将TEXT列用作UNIQUE KEY的一部分吗? 这非常低效!不要那样做! 我强烈建议你:

  • 添加以示例'description_hash' char(32) not null default ''
  • 命名的其他列
  • description字段的哈希值存储到其中。对于前者description_hash=MD5(description)
  • 将您的密钥更改为UNIQUE KEY (name, description_hash)

当然,您需要在代码中保持description_hash列的最新状态,但在大多数情况下,只需要进行少量代码更改即可。 或者您可以使用触发器来处理此问题。

答案 1 :(得分:4)

我有完全相同的问题。

我添加了一个新的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 ;

通过使用触发器并在哈希上添加UNIQUE索引,您可以确保哈希值始终是最新且唯一的。

答案 2 :(得分:1)

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));