我有一个情况,我需要存储 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
设置为空。你能建议我最好的表结构吗?
最佳答案
您可以设置一个虚拟的唯一值,但这不是最好的。
您可以管理应用程序逻辑中的唯一性,而不是最好的。
我认为最好是使用另一个只有两个字段的表:id
和twitter_username
,在twitter_username
上有一个唯一的键,并且仅在有时插入推特用户名。
此外,两个 id
列上应该存在一对一的关系。
关于MySQL 设置 NULLABLE 唯一字段,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3965235/