• SQL Server:主键与外键设置与相关理解


    一、定义与作用
    主键:表中能够唯一地辨别事物的属性。通过主键能够查询出表中一条完整的记录,同时使用主键能防止表中出现重复的记录,避免了数据的冗余。

    外键:通俗讲就是表中一个属性是来自另一张表的主键,该属性被称为该表的外键,外键可以有不止一个。外键存在的意义就是将事物与事物之间联系起来。

    二、SSMS设置表的主键与外键
    1、利用SQL语句建立查询设置
    举了一个学生、课程以及学生成绩关系表的例子:

    --代码
    create table [表名] (
    属性名 类型 primary key,
    属性名 类型 foreign key references [外键来自的表](外键的属性名),
    属性名 类型 not null,
    属性名 类型 null,
    ··· ···);

    --实例
    create table Student( --创建Student表
    Stu_id varchar(10) primary key, --学号Stu_id设置为主键
    Stu_name nvarchar(10) not null, --学生姓名
    Stu_sex nvarchar(2) default '男'); --学生性别,设置默认值为'男'


    create table Course( --创建课程信息表Course
    Course_id varchar(4) primary key, --课程编号Course_id设置为主键
    Course_name varchar(10) not null); --课程姓名


    create table StudentGrade( --创建成绩表
    stu_id varchar(10) foreign key references Student(Stu_id), --学生学号设置为外键
    Course_id varchar(4) foreign key references Course(Course_id), --课程号设置为外键
    Grade int null); --学生成绩
    2、利用鼠标点击操作创建(SSMS环境下)
    1) 设置主键
    a.在已创建Student表的前提下,点击Student表,右击,选择<设计>

     

    b.选择属性Stu_id,右击,选择设置主键

     

    设置完成,Course表主键设置同上。

    2)设置外键
    a.选择StudentGrade表,如1)中a所示选择<设计>

    b.选择属性Stu_id,右击,选择<关系>

     

    c.在弹出的窗口选择<添加>

     

    d.点击表和列规范最右边的三个小点(白色背景可能看不到,但点最右边也差不多了)

     

    e.关系名可以重新编辑,最好是能让自己记得住或看得懂含义的名字。将主键表和外键表设置完后点击右下方确认即可。

     

    三、主键表与外键表(个人的总结与反思...)
    刚开始上课的时候我就有点搞不清主键表与外键表,特别是设置的这张图里,

    (假设正在设置的这张StudentGrade表称为本表,其他表相对地称为外表),我认为外键表应该是指外键本来所在的表,即外表,因此应该设置为Student才对,但是这个框框一直编辑不了;而主键表应该指我正在编辑的这张StudentGrade表才对,但是当选择StudentGrade之后,下面列选项的框框就变成空的,没有列可选。

     

    但是将两个操作互换后又能得到想要的结果,所以当时就半懵半混过去了。

    然后偶然听到郝斌老师的课之后才恍然大悟。

    首先,主键表应该是指外键所来自的那个表,即例子中的Student表,在Student表中Stu_id是该表的主键,因此该表称为主键表;而外键表则指Stu_id扮演外键的时候所在的表,即例子中StudentGrade表。

  • 相关阅读:
    mysql之alter 字段的修改、添加、删除
    mysql之Percona-XtraDB-Cluster prohibits without an explicit primary key with pxc_strict_mode = ENFORCING or MASTER报错
    mysql之常用操作,创建库、表,删除库、表
    Spring Boot的消息之旅(一)
    Spring Boot的日志之旅(一)
    Spring Boot的缓存之旅(二)
    Spring Boot的缓存之旅(一)
    使用Druid数据库连接池
    Spring Boot的数据库之旅(二)
    Spring Boot的安全之旅(一)
  • 原文地址:https://www.cnblogs.com/hushzhang/p/16182305.html
Copyright © 2020-2023  润新知