码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 主键约束!


    目录

    主键约束(primary key,简称PK)非常重要五颗星*****

    1. 主键约束的相关术语?

    2. 什么是主键?有啥用?

    3. 主键的特征

    4. 怎么给一张表添加主键约束呢?

    4.1 单一主键:1个字段做主键

    4.2 使用表级约束添加主键

    4.3 复合主键:多个字段联合起来做主键

    5. 一张表中主键约束只能添加1个(主键只能有1个。)

    6. 主键值 

    7. 主键除了单一主键和复合主键之外,还可以这样进行分类?

    7.1 在实际开发中使用业务主键多,还是使用自然主键多一些?

    7.2 在mysql当中,有一种机制,可以帮助我们自动维护一个主键值


    主键约束(primary key,简称PK)非常重要五颗星*****

    1. 主键约束的相关术语?

    • 主键约束:就是一种约束。
    • 主键字段:该字段上添加了主键约束,这样的字段叫做主键字段
    • 主键值:主键字段中的每一个值都叫做主键值。

    2. 什么是主键?有啥用?

    • 主键值是每一行记录的唯一标识。
    • 主键值是每一行记录的身份证号!!!

    记住:任何一张表都应该有主键,没有主键,表无效!!

    3. 主键的特征

    not null + unique(主键值不能是NULL,同时也不能重复!)

    4. 怎么给一张表添加主键约束呢?

    4.1 单一主键:1个字段做主键

    drop table if exists t_vip;
    create table t_vip(
            id int primary key,  // 列级约束
            name varchar(255)
    );

    insert into t_vip(id,name) values(1,'zhangsan');
    insert into t_vip(id,name) values(2,'lisi');

     select * from t_vip;

    insert into t_vip(id,name) values(2,'wangwu');

    错误:id 不能重复

    insert into t_vip(name) values('zhaoliu');

    错误:id 不能为NULL

    4.2 使用表级约束添加主键

    drop table if exists t_vip;
    create table t_vip(
               id int,
               name varchar(255),
               primary key(id)  // 表级约束
    );

    insert into t_vip(id,name) values(1,'zhangsan'); 

    insert into t_vip(id,name) values(1,'lisi'); 

    错误:id 不能重复

    4.3 复合主键:多个字段联合起来做主键

    表级约束主要是给多个字段联合起来添加约束

    drop table if exists t_vip;
    create table t_vip(
              id int,
              name varchar(255),
              email varchar(255),
              primary key(id,name)
    );

    insert into t_vip(id,name,email) values(1,'zhangsan','zhangsan@123.com');
    insert into t_vip(id,name,email) values(1,'lisi','lisi@123.com'); 

    select * from t_vip;

    insert into t_vip(id,name,email) values(1,'lisi','lisi@123456.com'); 

    错误:id和name不能同时重复

    在实际开发中不建议使用复合主键,建议使用单一主键!因为主键值存在的意义就是这行记录的身份证号,只要意义达到即可,单一主键可以做到。复合主键比较复杂,不建议使用!!!

    5. 一张表中主键约束只能添加1个(主键只能有1个。)

    drop table if exists t_vip;
    create table t_vip(
             id int primary key,
             name varchar(255) primary key
    );

    6. 主键值 

    • 建议使用:int、bigint、char 等类型。
    • 不建议使用:varchar来做主键。主键值一般都是数字,一般都是定长的!

    7. 主键除了单一主键和复合主键之外,还可以这样进行分类?

    • 自然主键:主键值是一个自然数,和业务没关系。
    • 业务主键:主键值和业务紧密关联,例如拿银行卡账号做主键值,这就是业务主键!

    7.1 在实际开发中使用业务主键多,还是使用自然主键多一些?

    • 自然主键使用比较多,因为主键只要做到不重复就行,不需要有意义。
    • 业务主键不好,因为主键一旦和业务挂钩,那么当业务发生变动的时候,可能会影响到主键值,所以业务主键不建议使用,尽量使用自然主键。

    7.2 在mysql当中,有一种机制,可以帮助我们自动维护一个主键值

    auto_increment:表示自增,从1开始,以1递增!

    drop table if exists t_vip;
            create table t_vip(
                id int primary key auto_increment,
                name varchar(255)
    );


    insert into t_vip(name) values('zhangsan');
    insert into t_vip(name) values('zhangsan');
    insert into t_vip(name) values('zhangsan');
    insert into t_vip(name) values('zhangsan');
    insert into t_vip(name) values('zhangsan');
    insert into t_vip(name) values('zhangsan');
    insert into t_vip(name) values('zhangsan');
    insert into t_vip(name) values('zhangsan');

    select * from t_vip;

  • 相关阅读:
    【代码随想录】刷题笔记Day33
    uniapp开发微信小程序-用户授权登录和获取手机号码
    [好题][思维]Paimon Sorting 2021年ICPC南京站D
    一款免费无广、简单易用的安全软件:火绒安全软件
    新一代蒸馏算法
    B058-SpringBoot
    【笔记】ASP.NET Core 2.2 Web API —— 学习笔记
    羊了个羊的模式浅薄认知
    HTML5+CSS3+JS小实例:仿优酷视频轮播图
    Docker 进阶之镜像分层详解
  • 原文地址:https://blog.csdn.net/weixin_52385232/article/details/126049536
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号