我正在考虑一个小型的微博系统,我正在锻炼身体。我有三张桌子:与外键的微博表关系,追随者的麻烦?
users
id
username
tweets
id
tweet
followers
id_user
id_following
我如何为追随者建立关系? id_user和id_following都是与同一个表相关的PK?
这里是我的查询:
CREATE TABLE tweets (
tweet_id INT NOT NULL AUTO_INCREMENT,
tweet VARCHAR(140) NOT NULL,
PRIMARY KEY (tweet_id)
) ENGINE=INNODB;
CREATE TABLE users (
user_id INT NOT NULL AUTO_INCREMENT,
user VARCHAR(255) NOT NULL,
password VARCHAR(40) NOT NULL,
email VARCHAR(255) NOT NULL,
PRIMARY KEY (user_id)
) ENGINE=INNODB;
CREATE TABLE user_tweets (
id INT NOT NULL AUTO_INCREMENT,
id_user INT NOT NULL,
id_tweet INT NOT NULL,
PRIMARY KEY(id),
FOREIGN KEY (id_tweet)
REFERENCES tweets(tweeth_id)
ON UPDATE NO ACTION ON DELETE NO ACTION,
FOREIGN KEY (id_user)
REFERENCES users(user_id)) ENGINE=INNODB;
CREATE TABLE followers (
id_user INT NOT NULL REFERENCES users (user_id),
id_following INT NOT NULL REFERENCES users (user_id),
PRIMARY KEY (id_user, id_following)
) ENGINE=INNODB;
肯定的PK是(id_user,id_following),他们是单独FKS到同一个表?你有什么问题? – StevieG
在同一个表中有两个FK在另一个表中是PK是完全正确的。
– Andrey
请检查我的sql更新 – OralB