我的应用程序将允许用户拥有联系人列表。这是我目前的架构:数据库模式,1表或2表
CREATE TABLE IF NOT EXISTS `contact` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`user_id` int(11) NOT NULL,
`person_id` int(11) NOT NULL,
`create_time` int(11) NOT NULL,
PRIMARY KEY (`id`),
UNIQUE KEY `user_id` (`user_id`,`person_id`)
) ENGINE=InnoDB;
CREATE TABLE IF NOT EXISTS `contact_request` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`user_id` int(11) NOT NULL,
`person_id` int(11) NOT NULL,
`create_time` int(11) NOT NULL,
PRIMARY KEY (`id`),
UNIQUE KEY `user_id` (`user_id`,`person_id`)
) ENGINE=InnoDB;
CREATE TABLE IF NOT EXISTS `user` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`email_address` varchar(50) NOT NULL,
`username` varchar(32) NOT NULL,
`password` varchar(32) NOT NULL,
PRIMARY KEY (`id`),
UNIQUE KEY `email_address` (`email_address`),
UNIQUE KEY `username` (`username`)
) ENGINE=InnoDB;
当用户试图在另一个用户添加为联系人,记录在contact_request表中创建。如果接收请求的用户拒绝该请求,则删除contact_request记录。如果用户决定接受请求,则contact_request表中的数据将添加到联系人表中,然后从contact_request表中删除。
我意识到我可以通过另一种方式做到这一点,我删除contact_request表并添加另一个字段到联系人表例如:状态,表示联系人是否刚刚被请求或者它是否是一个接受的请求。
CREATE TABLE IF NOT EXISTS `contact` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`user_id` int(11) NOT NULL,
`person_id` int(11) NOT NULL,
`status` tinyint(1) not null,
`create_time` int(11) NOT NULL,
PRIMARY KEY (`id`),
UNIQUE KEY `user_id` (`user_id`,`person_id`)
) ENGINE=InnoDB;
我看到的好处是我会有1个表少。我目前没有看到由于这种改变而发生的问题。这值得改变吗?我可能没有意识到哪种方法还有其他优点?建议哪个?
我想我应该提到我会同时显示联系人和联系请求。我决定改变它使用单个表格,如果我有任何问题,请回复。谢谢您的回答。 – 2011-03-14 18:48:14