데이터 베이스 MySQL 튜토리얼 讨论SQL Server 表的主键问题

讨论SQL Server 表的主键问题

Jun 07, 2016 pm 04:18 PM
server 기본 키 논의하다 질문

关于数据库的逻辑设计,是一个很广泛的问题。本文主要针对开发应用中遇到在MS SQL Server上进行表设计时,对表的主键设计应注意的问题以及相应的解决办法。 主键设计现状和问题 关于数据库表的主键设计,一般而言,是根据业务需求情况,以业务逻辑为基础,形

  关于数据库的逻辑设计,是一个很广泛的问题。本文主要针对开发应用中遇到在MS SQL Server上进行表设计时,对表的主键设计应注意的问题以及相应的解决办法。

  主键设计现状和问题

  关于数据库表的主键设计,一般而言,是根据业务需求情况,以业务逻辑为基础,形成主键。

  比如,销售时要记录销售情况,一般需要两个表,一个是销售单的概要描述,记录诸如销售单号、总金额一类的情况,另外一个表记录每种商品的数量和金额。对于第一个表(主表),通常我们以单据号为主键;对于商品销售的明细表(从表),我们就需要将主表的单据号也放入到商品的明细表中,使其关联起来形成主从关系。同时该单据号与商品的编码一起,形成明细表的联合主键。这只是一般情况,我们稍微将这个问题延伸一下:假如在明细中,我们每种商品又可能以不同的价格方式销售。有部分按折扣价格销售,有部分按正常价格销售。要记录这些情况,那么我们就需要第三个表。而这第三个表的主键就需要第一个表的单据号以及第二个表的商品号再加上自身需要的信息一起构成联合主键;又或者其他情况,在第一个主表中,本身就是以联合方式构成联合主键,那么也需要在从表中将主表的多个字段添加进来联合在一起形成自己的主键。

  数据冗余存储:随着这种主从关系的延伸,数据库中需要重复存储的数据将变得越来越庞大。或者当主表本身就是联合主键时,就必须在从表中将所有的字段重新存储一次。

  SQL复杂度增加:当存在多个字段的联合主键时,我们需要将主表的多个字段与子表的多个字段关联以获取满足某些条件的所有详细情况记录。

  程序复杂度增加:可能需要传递多个参数。

  效率降低:数据库系统需要判断更多的条件,SQL语句长度增加。同时,联合主键自动生成联合索引

  WEB分页困难:由于是联合主键方式(对于多数的子表),那么在WEB页面上要进行分页处理时,在自关联时,难于处理。

  解决方案

  从上面,我们已经看到现有结构存在着相当多的弊端,主要是导致程序复杂、效率降低并且不利于分页。

  为解决上述问题,本文提出:当应用系统后台数据库表间存在主从关系时,数据库表额外增加一非业务字段作为主键,该字段为数值型;或者当该表需要在应用中进行分页查询时,也应考虑如此设计。一般地,我们也可以几乎为任何表增加一个与业务逻辑无关的字段作为该表的主键字段。

  由于该字段要作为表的主键,那么其首要条件是要保证在该表中要具有唯一性。同时,结合SQL Server数据库自身的特性,可以为其建立一个自增列:

  以下为引用的内容:

  create TABLE T_PK_DEMO

  (

  U_ID  BIGINT NOT NULL IDENTITY(1,1),

  --唯一标识记录的ID

  COL_OTHER VARchar(20) NOT NULL ,

  --其他列

  CONSTRAINT PK_T_PK_DEMO PRIMARY KEY NONCLUSTERED

  (U_ID)--定义为主键

  )

  但是,SQL Server中的自增列却存在一个比较尴尬的事实,那就是该字段一旦定义和使用,用户无法直接干预该字段的值,完全由数据库系统自身控制:

  完全数据库系统控制,用户无法修改值

  在数据库的发布和订阅时,使用自增列会比较麻烦

  恢复部分数据时,使用自增列会比较麻烦

  该列的值必须在插入数据后才能获取

  鉴于此,建议不以自增列的方式来定义,而是参考Oracle数据库系统中序列,在SQL Server系统中实现类似Oracle数据库系统序列功能。这个具体在下面的小节中介绍。我们只需要按照普通字段的定义方式修改表定义为:

  以下为引用的内容:

  create TABLE T_PK_DEMO

  (

  U_ID  BIGINT NOT NULL ,--唯一标识记录的ID

  COL_OTHER VARchar(20) NOT NULL ,--其他列

  CONSTRAINT PK_T_PK_DEMO PRIMARY KEY NONCLUSTERED (U_ID)--定义为主键

  )

  参照Oracle序列的功能,我们需要在SQL Server数据库中创建一个新表,以管理序列值:

  以下为引用的内容:

  create TABLE T_DB_SEQ

  (

  SEQ_NAMEVARchar(50) NOT NULL ,--序列名称

  SEQ_OWNER  VARchar(50) NOT NULL DEFAULT ’DBO’,

  --序列所有者(SYSTEM_USER)

  SEQ_CURRENT BIGINT NOT NULL DEFAULT 0,--序列当前值

  SEQ_MIN BIGINT NOT NULL DEFAULT 0,--序列最小值

  SEQ_MAX BIGINT NOT NULL DEFAULT 0,--序列最小值

  SEQ_MAX BIGINT NOT NULL DEFAULT 0,--序列最大值

  SEQ_STEPINT NOT NULL DEFAULT 1,--序列增长步长

  IF_CYCLEINT NOT NULL DEFAULT 0,--是否循环(0,不循环;1,循环)

  CONSTRAINT T_DB_SEQ PRIMARY KEY CLUSTERED

  (SEQ_NAME,SEQ_OWNER)--主键

  )

  应用系统为需要创建自增列的表创建一个序列名称,在表“T_DB_SEQ”中反映为数据库中的一行。

  第一,需要为需要建立序列的表创建一个序列。采用方法:F_create_SEQ(序列名)。该函数传入序列的名称,在表“T_DB_SEQ”插入一行。序列的所有者,采用系统变量SYSTEM_USER。

  第二,获取下一个值。采用方法:F_GET_NEXT_SEQ_VAL(序列名)。该函数根据序列名获取该序列的下一个值,根据当前值与增长步长得到。同时,该函数保证在同时获取同一个序列时,应保证并发一致性。

  第三、将返回值返回到应用使用。

  此外,为保证应用的完整性,可能还需要提供一些方法的重载方法,同时提供一些其他方法:

  获取序列当前值:F_GET_SEQ_CUR_VAL(序列名)

  设置序列值:F_SET_SEQ_VAL(序列名)

  删除序列:F_DEL_SEQ(序列名)

  判断序列是否存在:F_SEQ_exists(序列名)

  在主从关系的表设计中,子表也使用序列字段作为唯一主键,将父表的序列字段作为外键关联:

  以下为引用的内容:

  create TABLE T_PK_DEMO_C

  (

  U_ID  BIGINT NOT NULL ,--唯一标识记录的ID

  COL_OTHER VARchar(20) NOT NULL ,--其他列

  P_ID  INT NOT NULL ,--父表ID

  CONSTRAINT PK_T_PK_DEMO_C PRIMARY KEY

  NONCLUSTERED (U_ID)--定义为主键

  CONSTRAINT FK_T_PK_DEMO_C FOREIGN KEY (P_ID)

  REFERENCES T_PK_DEMO(U_ID) ON delete CASCADE,

  )

  使用序列的问题及解决办法

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

Windows 서버 백업을 설치, 제거 및 재설정하는 방법 Windows 서버 백업을 설치, 제거 및 재설정하는 방법 Mar 06, 2024 am 10:37 AM

WindowsServerBackup은 WindowsServer 운영 체제와 함께 제공되는 기능으로, 사용자가 중요한 데이터 및 시스템 구성을 보호하고 중소기업 및 대기업 수준의 기업에 완벽한 백업 및 복구 솔루션을 제공하도록 설계되었습니다. Server2022 이상을 실행하는 사용자만 이 기능을 사용할 수 있습니다. 이 문서에서는 WindowsServerBackup을 설치, 제거 또는 재설정하는 방법을 설명합니다. Windows Server 백업을 재설정하는 방법 서버 백업에 문제가 있거나 백업에 너무 오랜 시간이 걸리거나 저장된 파일에 액세스할 수 없는 경우 Windows Server 백업 설정을 재설정하는 것을 고려할 수 있습니다. Windows를 재설정하려면

jQuery가 양식 요소 값을 얻을 수 없는 문제를 해결하는 방법 jQuery가 양식 요소 값을 얻을 수 없는 문제를 해결하는 방법 Feb 19, 2024 pm 02:01 PM

jQuery.val()을 사용할 수 없는 문제를 해결하려면 구체적인 코드 예제가 필요합니다. 프론트 엔드 개발자에게는 jQuery를 사용하는 것이 일반적인 작업 중 하나입니다. 그중에서도 .val() 메서드를 사용하여 양식 요소의 값을 가져오거나 설정하는 것은 매우 일반적인 작업입니다. 그러나 특정한 경우에는 .val() 메서드를 사용하지 못하는 문제가 발생할 수 있습니다. 이 문서에서는 몇 가지 일반적인 상황과 해결 방법을 소개하고 구체적인 코드 예제를 제공합니다. 문제 설명 jQuery를 사용하여 프런트 엔드 페이지를 개발할 때 때때로 다음과 같은 문제가 발생할 수 있습니다.

일반적인 iPhone 문제를 진단하는 방법을 가르쳐주세요. 일반적인 iPhone 문제를 진단하는 방법을 가르쳐주세요. Dec 03, 2023 am 08:15 AM

강력한 성능과 다재다능한 기능으로 잘 알려진 iPhone은 복잡한 전자 장치에서 흔히 발생하는 문제인 가끔씩 발생하는 문제나 기술적인 어려움으로부터 자유롭지 않습니다. iPhone 문제를 경험하면 실망스러울 수 있지만 일반적으로 알람은 필요하지 않습니다. 이 종합 가이드에서는 iPhone 사용과 관련하여 가장 일반적으로 직면하는 문제 중 일부를 쉽게 설명하는 것을 목표로 합니다. 당사의 단계별 접근 방식은 이러한 일반적인 문제를 해결하는 데 도움을 주고 장비를 최상의 작동 순서로 되돌릴 수 있는 실용적인 솔루션과 문제 해결 팁을 제공하도록 설계되었습니다. 결함이 있거나 더 복잡한 문제에 직면하더라도 이 문서는 문제를 효과적으로 해결하는 데 도움이 될 수 있습니다. 일반적인 문제 해결 팁 특정 문제 해결 단계를 진행하기 전에 다음은 몇 가지 유용한 정보입니다.

클러스터링 알고리즘의 클러스터링 효과 평가 문제 클러스터링 알고리즘의 클러스터링 효과 평가 문제 Oct 10, 2023 pm 01:12 PM

클러스터링 알고리즘에서 클러스터링 효과 평가 문제에는 특정 코드 예제가 필요합니다. 클러스터링은 데이터를 클러스터링하여 유사한 샘플을 하나의 범주로 그룹화하는 비지도 학습 방법입니다. 클러스터링 알고리즘에서는 클러스터링의 효과를 어떻게 평가하는가가 중요한 문제입니다. 이 기사에서는 일반적으로 사용되는 몇 가지 클러스터링 효과 평가 지표를 소개하고 해당 코드 예제를 제공합니다. 1. 클러스터링 효과 평가 지수 실루엣 계수 실루엣 계수는 표본의 근접성 및 다른 클러스터와의 분리 정도를 계산하여 클러스터링 효과를 평가합니다.

머신러닝 모델의 일반화 능력 문제 머신러닝 모델의 일반화 능력 문제 Oct 08, 2023 am 10:46 AM

기계 학습 모델의 일반화 기능에는 특정 코드 예제가 필요합니다. 기계 학습의 개발 및 적용이 점점 더 널리 보급됨에 따라 사람들은 기계 학습 모델의 일반화 기능에 점점 더 많은 관심을 기울이고 있습니다. 일반화 능력은 레이블이 지정되지 않은 데이터에 대한 기계 학습 모델의 예측 능력을 의미하며, 현실 세계에서 모델의 적응성으로도 이해될 수 있습니다. 좋은 머신러닝 모델은 높은 일반화 능력을 갖추고 새로운 데이터에 대해 정확한 예측을 할 수 있어야 합니다. 그러나 실제 응용에서는 훈련 세트에서는 잘 수행되지만 테스트 세트에서는 실패하거나 실제 모델에서 실패하는 모델을 자주 접하게 됩니다.

Redmi K70Pro에서 리턴 키와 홈 키를 설정하는 방법은 무엇입니까? Redmi K70Pro에서 리턴 키와 홈 키를 설정하는 방법은 무엇입니까? Feb 23, 2024 pm 01:40 PM

물론, 각 연령층마다 휴대전화에 대한 요구가 다릅니다. 현재 가장 인기 있는 모델 중 하나인 RedmiK70Pro는 다양한 연령대의 소비자 요구를 충족할 수 있는 다양한 내부 기능과 서비스를 갖추고 있습니다. Redmi K70Pro에서 리턴 키와 홈 키를 설정하는 방법은 무엇입니까? 또한 명확하게 이해해야 합니다. 이해한 후에만 이 휴대폰을 구입할지 여부를 결정할 수 있습니다. 그런 다음 편집자를 따라 다음 내용을 살펴보십시오! Redmi K70Pro에서 리턴 키와 홈 키를 설정하는 방법은 무엇입니까? 휴대폰의 설정 메뉴에 액세스하려면 알림 창을 아래로 내리거나 홈 화면에서 설정 아이콘을 찾아 설정 인터페이스를 열 수 있습니다. 설정 인터페이스에서 "버튼" 또는 "탐색 표시줄"을 찾아서 클릭하세요.

Windows Server 2025 미리보기 버전은 업데이트를 환영하며 Microsoft는 내부자 테스트 경험을 개선합니다. Windows Server 2025 미리보기 버전은 업데이트를 환영하며 Microsoft는 내부자 테스트 경험을 개선합니다. Feb 19, 2024 pm 02:36 PM

Microsoft는 Windows Server 빌드 26040 버전을 출시하면서 제품의 공식 이름을 Windows Server 2025로 발표했습니다. Windows11WindowsInsiderCanaryChannel 버전 build26040도 출시되었습니다. 일부 친구들은 수년 전에 누군가 Windows NT를 워크스테이션 모드에서 서버 모드로 성공적으로 전환하여 다양한 버전의 Microsoft 운영 체제 간의 공통점을 보여주었다는 것을 아직도 기억할 것입니다. 마이크로소프트의 현재 서버 운영체제 버전과 윈도우 11 사이에는 뚜렷한 차이가 있지만, 세부 사항에 주목하는 사람들은 윈도우 서버가 왜 브랜드를 업데이트했는지,

강화 학습의 보상 설계 문제 강화 학습의 보상 설계 문제 Oct 08, 2023 pm 01:09 PM

강화학습의 보상 설계 문제에는 구체적인 코드 예제가 필요합니다. 강화학습은 환경과의 상호작용을 통해 누적 보상을 극대화하는 조치를 취하는 방법을 학습하는 것이 목표인 기계 학습 방법입니다. 강화 학습에서 보상은 에이전트의 학습 과정에서 중요한 역할을 하며 에이전트의 행동을 안내하는 데 사용됩니다. 그러나 보상 설계는 어려운 문제이며 합리적인 보상 설계는 강화 학습 알고리즘의 성능에 큰 영향을 미칠 수 있습니다. 강화 학습에서 보상은 에이전트 대 환경으로 생각할 수 있습니다.

See all articles