SQL数据库里面怎样设置表与表之间的关联

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了SQL数据库里面怎样设置表与表之间的关联相关的知识,希望对你有一定的参考价值。

设置关联的两表或者多表、通过外键关联、外键字段是从表中的字段、外键(FOREIGN KEY)字段需要在主表做主键(PRIMARY KEY)、
比如
学生表(学号 主键,姓名) 主表
课程表(课号 主键,课名) 主表
选了表(学号 外键, 课号 外键,成绩) 从表
这样三个表就关联了、记住建表顺序、先主表、再从表
然后可以使用代码或者图形界面管理器创建外键、创建完就关联了

外键的取值必须是主键的值追问

谢谢!!

参考技术A 你说的关联是指外键不?

SQL Server Management Studio
展开所要设置的表下面的选项,可以新建外键。这样直观,简单。
也可以用SQL语句。本回答被提问者和网友采纳
参考技术B sql中表关联的建立方法:
1、最常用的一种: 减少重复数据.表A中拥有外键,表B的数据基本是不允许删除的.这时选择对 INSERT 和 UPDATE 强制关系即可.
2、其次,是增加一个从属表. 如果表A删除一条记录时,表B中也随着删除一条相关联的记录,那么外键关系中,表A的主键是表B的外键。这种关系,实际上表B是表A的从属表(即表A是父表),选择对 INSERT 和 UPDATE 强制关系时,如果向表B中插入数据,表A中必须已经存在对应的记录。选择级联删除相关的字段时,删除表A中的一条记录,就会删除对应的表B中的一条记录。
参考技术C 有表关系的那个打开,然后右键设置去吧。试验几次就会啦啦。追问

谢谢

参考技术D 各种链接
左链接,右链接,内链接,外链接等

SQL表关联赋值系统表表数据删除

1. 表与表的关联赋值(用于表与表之间有关联字段,数据互传)

  双表关联赋值

  UPDATE #B SET #B.D=#A.B from #B inner join #A on #B.C=#A.A

   多表关联赋值

  update a set a.e=c.n from a left join b on a.e=b.j left join c on b.k=c.m

2. 两种删除方式(TRUNCATE TABLE <--> DELETE FROM

  TRUNCATE TABLE #USER

  删除极快,无日志所以无法恢复,且只能用于表数据全部删除
  DELETE FROM #USER WHERE ...

  删除会产生日志信息,可用于数据恢复,可附加条件选择性删除

3. 利用系统表数据构建SQL查询语句

  查询表的字段以及字段类型

  SELECT NAME,SYSTEM_TYPE_ID FROM SYS.COLUMNS WHERE OBJECT_ID=OBJECT_ID(N‘费用明细‘,N‘U‘)

  构建SQL查询语句,实现字段的规范

  SELECT ‘(case when isnull(b.‘+NAME+‘,‘‘‘+(CASE SYSTEM_TYPE_ID WHEN 167 THEN ‘‘ WHEN 108 THEN ‘0‘ WHEN 42 THEN ‘1899-12-30‘ ELSE ‘‘   END)+‘‘‘)=‘‘‘+(CASE SYSTEM_TYPE_ID WHEN 167 THEN ‘‘ WHEN 108 THEN ‘0‘ WHEN 42 THEN ‘1899-12-30‘ ELSE ‘‘ END)+‘‘‘ then ‘‘‘+(CASE   SYSTEM_TYPE_ID WHEN 167 THEN ‘-‘ WHEN 108 THEN ‘0‘ WHEN 40 THEN ‘1899-12-30‘ WHEN 42 THEN ‘1899-12-30‘ ELSE ‘-‘ END)+‘‘‘ else   b.‘+NAME+‘ end) AS ‘+NAME+‘, ‘ FROM SYS.COLUMNS
  WHERE OBJECT_ID=OBJECT_ID(N‘住院费用明细‘,N‘U‘)

 

 

 

以上是关于SQL数据库里面怎样设置表与表之间的关联的主要内容,如果未能解决你的问题,请参考以下文章

SQL数据库中表与表之间的关联怎么建立

已经建立了两个表,请问如何用SQL语句建立关联?

已经建立了两个表,请问如何用SQL语句建立关联?

SQL外键foreign key 表与表之间的三种关系

sql,表与表之间列的包含查询

SQL表关联赋值系统表表数据删除