数据库 – 当我想存储从下拉列表或用户输入中选择的值时,db设计中的最佳实践是什么?

前端之家收集整理的这篇文章主要介绍了数据库 – 当我想存储从下拉列表或用户输入中选择的值时,db设计中的最佳实践是什么?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我试图找到设计数据库的最佳方法,以便允许以下场景:

>向用户显示大学下拉列表(例如)
>用户从列表中选择他/她的大学(如果存在)
>如果大学不存在,他应该在一个文本框中进入他自己的大学(有点像其他:[___________])

我应该如何设计数据库来处理这种情况,因为我可能想要使用大学ID进行排序(可能仅针对内置大学而不是用户输入的大学)

谢谢!

我只是想让它类似于Facebook如何处理这种情况.如果用户选择他的教育(通过实际输入我不关心的组合框)并选择其中一个返回值,Facebook会做什么?

在我的猜测中,它会在多对多表中插入UserID和EducationID.现在如果用户输入的内容根本不在数据库中?它仍然存储在他的个人资料中,但在哪里?
typing “St”…suggesting Stanford http://i43.tinypic.com/hufztt.jpg

typing non-existing university http://i41.tinypic.com/14j56s8.jpg

解决方法

CREATE TABLE university
(
  id smallint NOT NULL,name text,public smallint,CONSTRAINT university_pk PRIMARY KEY (id)
);

CREATE TABLE person
(
  id smallint NOT NULL,university smallint,-- more columns here...
  CONSTRAINT person_pk PRIMARY KEY (id),CONSTRAINT person_university_fk FOREIGN KEY (university)
      REFERENCES university (id) MATCH SIMPLE
      ON UPDATE NO ACTION ON DELETE NO ACTION
);

对于系统中的Unis,public设置为1,对于user-entered-unis,设置为0.

猜你在找的MsSQL相关文章