首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >MySQL:如何将varchar(255)唯一列更改为唯一文本而不是NULL?

MySQL:如何将varchar(255)唯一列更改为唯一文本而不是NULL?
EN

Stack Overflow用户
提问于 2011-01-20 07:49:14
回答 3查看 16.9K关注 0票数 5

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

注意:要更改的列其属性类型是另一列的唯一键组合。例如。

唯一的密钥(名称、描述)

列描述目前在varchar(255)中。它不能被改变,因为:

错误1170 (42000):BLOB/TEXT列“description”用于没有密钥长度的密钥规范中

我需要它是文字,否则我需要重现整件事??我已经有了一些繁琐而重要的数据。重新创作会很麻烦的。

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2011-01-20 08:36:34

您打算使用文本列作为唯一键的一部分吗?效率很低!别干那事!我强烈建议你:

例如,'description_hash' char(32) not null default ''

  • Store
  • description字段添加了其他名为hash-
  • 的列。为了前夫。description_hash=MD5(description)
  • Change你的钥匙到UNIQUE KEY (name, description_hash)

当然,您需要在代码中保持description_hash列的更新,但正如所见--在大多数情况下,只需要很少的代码更改。或者你可以用触发器来处理这件事。

票数 12
EN

Stack Overflow用户

发布于 2012-06-13 22:29:40

我也有同样的问题。

我添加了一个新的char(32)列(我将其命名为hash,并在其上添加了一个唯一的索引)和两个触发器。

代码语言:javascript
复制
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 ;

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

票数 4
EN

Stack Overflow用户

发布于 2011-01-20 07:52:07

代码语言:javascript
复制
alter table your_table
modify column your_column text not null;

作为唯一的键

代码语言:javascript
复制
alter table your_table 
add unique index your_index_name (your_column(your_length));

your_length =允许1000个字节

最大密钥长度为1000个字节。这也可以通过更改源代码和重新编译来更改。对于键大于250个字节的情况,将使用比默认的1024字节更大的键块大小。

两个长度(description +另一列不能超过1000),因此

代码语言:javascript
复制
alter table your_table 
add unique index your_index_name (description(800), another_column(200));
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/4744617

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档