MySQL 设置 NULLABLE 唯一字段

标签 mysql unique-key

我有一个情况,我需要存储 Twitter 用户名、电子邮件和其他一些字段以保持唯一。但是,我只能稍后设置 Twitter 用户名。不在注册过程中。我该如何在 SQL 中处理这个问题?

这是我当前的 SQL 结构:

CREATE TABLE `kios_users` (
 `id` int(11) NOT NULL AUTO_INCREMENT,
 `username` varchar(32) NOT NULL,
 `password` varchar(60) NOT NULL,
 `email` varchar(100) NOT NULL,
 `no_hp` varchar(15) NOT NULL,
 `twitter_oauth_token` varchar(60) NOT NULL,
 `twitter_oauth_token_secret` varchar(60) NOT NULL,
 `twitter_username` varchar(32) NULL,
 `verify_level` enum('just_reg','hp_ok','all_ok') NOT NULL,
 PRIMARY KEY (`id`),
 UNIQUE KEY `email` (`email`),
 UNIQUE KEY `no_hp` (`no_hp`),
 UNIQUE KEY `username` (`username`),
 UNIQUE KEY `twitter_username` (`twitter_username`)
) ENGINE=MyISAM

使用这种结构,我无法将 twitter_username 设置为空。你能建议我最好的表结构吗?

最佳答案

您可以设置一个虚拟的唯一值,但这不是最好的。 您可以管理应用程序逻辑中的唯一性,而不是最好的。 我认为最好是使用另一个只有两个字段的表:idtwitter_username,在twitter_username上有一个唯一的键,并且仅在有时插入推特用户名。 此外,两个 id 列上应该存在一对一的关系。

关于MySQL 设置 NULLABLE 唯一字段,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3965235/

相关文章:

java - 在JSP上使用超链接显示关系数据库记录的数据库

sql - 使用 INSERT ON CONFLICT 在跨多列的唯一约束上发生冲突,其中一列可能为空

python - 如何使用连接删除mysql行

javascript - 使用 AJAX 和 PHP 将值插入 MYSQL db OnChange 的下拉框

我的管理员登录页面中的 PHP session 和 Cookie 错误

java - 如果 hashString 是纳米时间,Hashing.crc32 是否会生成一个唯一的字符串?

sql-server - 在 sql server 08 中如何使用 base 36 跳过 Id 列的粗俗单词?

primary-key - 黑白主键和唯一键有什么区别

random - 64 位随机 ID 是否足以容纳大约 1000 万个条目?

mysql - 表 'performance_schema.session_variables' 不存在