位置: 编程技术 - 正文

初探SQL语句复合主键与联合主键(sql 复合语句)

编辑:rootadmin

推荐整理分享初探SQL语句复合主键与联合主键(sql 复合语句),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:pl/sql中的复合变量,sql复合条件查询,sql语句复合查询,sql语句复用,sql复合主键的写法,复合sql怎么写,sql复合主键语句,复合sql怎么写,内容如对您有帮助,希望把文章链接给更多的朋友!

一、复合主键

所谓的复合主键 就是指你表的主键含有一个以上的字段组成,不使用无业务含义的自增id作为主键。比如

上面的name和id字段组合起来就是你test表的复合主键 ,它的出现是因为你的name字段可能会出现重名,所以要加上ID字段这样就可以保证你记录的唯一性 ,一般情况下,主键的字段长度和字段数目要越少越好 。

这里就会有一个疑惑&#; 主键是唯一的索引,那么为何一个表可以创建多个主键呢?

其实“主键是唯一的索引”这话有点歧义的。举个例子,我们在表中创建了一个ID字段,自动增长,并设为主键,这个是没有问题的,因为“主键是唯一的索引”,ID自动增长保证了唯一性,所以可以。

此时,我们再创建一个字段name,类型为varchar,也设置为主键,你会发现,在表的多行中你是可以填写相同的name值的,这岂不是有违“主键是唯一的索引”这句话么?

所以我才说“主键是唯一的索引”是有歧义的。应该是“当表中只有一个主键时,它是唯一的索引;当表中有多个主键时,称为复合主键,复合主键联合保证唯一索引”。

为什么自增长ID已经可以作为唯一标识的主键,为啥还需要复合主键呢。因为,并不是所有的表都要有ID这个字段,比如,我们建一个学生表,没有唯一能标识学生的ID,怎么办呢,学生的名字、年龄、班级都可能重复,无法使用单个字段来唯一标识,这时,我们可以将多个字段设置为主键,形成复合主键,这多个字段联合标识唯一性,其中,某几个主键字段值出现重复是没有问题的,只要不是有多条记录的所有主键值完全一样,就不算重复。

初探SQL语句复合主键与联合主键(sql 复合语句)

二、联合主键

联合主键顾名思义就是多个主键联合形成一个主键组合(主键原则上是唯一的,别被唯一值所困扰。)

联合主键的意义:用2个字段(或者多个字段,后面具体都是用2个字段组合)来确定一条记录,说明,这2个字段都不是唯一的,2个字段可以分别重复,这么设置的好处,可以很直观的看到某个重复字段的记录条数。

一个简单的例子

主键A跟主键B组成联合主键

主键A跟主键B的数据可以完全相同,联合就在于主键A跟主键B形成的联合主键是唯一的。

下例主键A数据是1,主键B数据也是1,联合主键其实是,这个是唯一值,绝对不充许再出现这个唯一值。(这就是多对多关系)

主键A数据 主键B数据

1      1 2      2 3      3

主键A与主键B的联合主键值最多也就是

总结: 以我来看复合主键就是含有一个以上的字段组成,如ID+name,ID+phone等,而联合主键要同时是两个表的主题组合起来的。这是和复合主键最大的区别!

标签: sql 复合语句

本文链接地址:https://www.jiuchutong.com/biancheng/348350.html 转载请保留说明!

上一篇:SQL执行步骤的具体分析(最全的sql执行顺序)

下一篇:MySQL两种临时表的用法详解(mysql 临时表)

  • 补做前几年税审对报税税务评级有什么影响?
  • 企业所得税留抵税额会显示在申报表上吗?
  • 什么是应交增值税
  • 税后经营净利率和营业净利率的区别
  • 交通运输印花税怎么申报
  • 个体户查账征收怎么交税?
  • 小规模增值税税率表2023年最新版
  • 信息技术服务可以简易征收吗
  • 工资代扣工会会费
  • 用excel怎么制作思维导图
  • 管理费用会计科目代码是多少
  • 银行存款日记账与银行对账单之间的核对属于
  • 增值税农产品抵扣政策
  • 分公司是否可以贷款
  • 安装工程中安装工程与市政路灯工程界定不正确的是
  • 企业担保形成损失的原因
  • 专项维修基金所得税可税前扣除吗?
  • 存货跌价准备如何结转
  • 建筑施工单位可以安装电表吗
  • 外币账户和外汇账户一样吗?
  • 季度不超过30万免税分录
  • 进项票税率不同怎么处理
  • 为什么手机连不上热点
  • 促销费影响主营利润吗
  • 销售原材料计入哪里
  • 金蝶系统怎么修改库存数量
  • 关闭windows安全中心拦截
  • 跨年发票税务处理两大原则
  • php获取指定日期的时间戳
  • php的api调用方法
  • 多交的所得税退回来账务处理
  • 购进商品怎么做会计分录
  • 国地税合并后税种有哪些
  • 好奇地看着我
  • 总结一些php中好用的软件
  • 分页page
  • 怎么用ai做vi
  • 深度学习之bottleneck layer
  • 长期待摊费用计提摊销的会计分录
  • 辅助生产车间工人工资计入
  • 小规模纳税人劳务费税率
  • 红字更正法适用于更正什么样的错误
  • 钉钉财务软件怎么用
  • 银行承兑到期后未兑付
  • 借方记录什么的增加
  • 贷款减值准备是什么意思
  • 股东打到公帐上怎么做账
  • 多付款项退回怎么做账
  • 转出未交增值税和未交增值税区别
  • 免征的增值税账务处理
  • 带赠品折扣的发票怎么开
  • 预计负债可以获取利润吗
  • 待报解预算收入给我转了钱是什么意思
  • 停车费专用发票
  • sql优化的一般步骤
  • Windows Server 2008的节能降耗
  • centos7.0网络配置
  • xp文件夹选项不见了怎么办
  • linux批量替换文件夹名称
  • win7系统怎么开wifi热点
  • rsync windows linux
  • linux怎么下载安装腾讯Tim?
  • win7点开始一直跳闪
  • 电脑windows8怎么样
  • jquery window
  • CSS锦囊
  • div 绝对位置
  • html里id
  • html中的表格
  • android内存泄露 工具
  • python爬虫怎么做
  • js打印命令
  • 上海电子发票试点
  • 一般纳税人出售房产怎么开票
  • 国家税务总局,湖北省税务局
  • 增值税电子普通发票需要盖章吗
  • 如何查看税务登记记号
  • 杭州地税局办事大厅
  • 教育费附加地方教育费附加税率
  • 普通版怎么下载
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设