当数据库创建表时,每个表只能有一个主键,但是如果想让多个列都成为主键时,就要用到复合主键。一、主键唯一约束我们知道当某列为主键时,Oracle会自动将此列创
当数据库创建表时,每个表只能有一个主键,但是如果想让多个列都成为主键时,就要用到复合主键。
一、主键唯一约束
我们知道当某列为主键时,Oracle会自动将此列创建唯一约束。也就是说不允许有相同的值出现。
如:
CREATE TABLE T
(
ID NUMBER,
NAME VARCHAR2(10),
constraint t_pk primary key (ID)
);
table T 已创建。
INSERT INTO T VALUES(1,'A');
1 行已插入。
insert into T VALUES(1,'B');
SQL 错误: ORA-00001: 违反唯一约束条件 (TEST.T_PK)
复合主键创建的约束指的是不允许三个值都重复的数据插入
如:
CREATE TABLE T
(
ID1 NUMBER,
ID2 NUMBER,
ID3 NUMBER,
NAME VARCHAR2(10),
constraint t_pk primary key (ID1,ID2,ID3)
);
table T 已创建。
INSERT INTO T VALUES(1,1,1,'A');
1 行已插入。
INSERT INTO T VALUES(1,1,2,'B');
1 行已插入。
INSERT INTO T VALUES(1,2,1,'A');
1 行已插入。
INSERT INTO T VALUES(1,1,2,'B');
SQL 错误: ORA-00001: 违反唯一约束条件 (TEST.T_PK)
二、主键索引
当创建主键时Oracle会自动创建索引。
如:
CREATE TABLE T1
(
ID NUMBER,
NAME VARCHAR2(10),
CONSTRAINT T1_PK PRIMARY KEY (ID)
);
...插入部分数据...
SELECT * FROM T1 WHERE id = 10;
查看Oracle的解释计划
很明显Oracle使用了索引来查询。
而当执行一下查询时由于没有索引列,所以使用的是全表扫描查询。
SELECT * FROM T1 where name = 'A';
SELECT * FROM T1 ;
当创建复合索引时包含全部索引列时Oracle会以索引方式进行查询。
SELECT * FROM T WHERE ID1 = 2 AND ID2 = 3 AND ID3 = 1;
当条件包含部分索引列时会发生两种情况。我们重新创建一张表REPOLICYSHARE,向表内插入500000行数据。
CREATE TABLE REPOLICYSHARE
(
POLICYNO VARCHAR2(22),
DANGERNO NUMBER(8,0),
REPOLICYNO VARCHAR2(22) NOT NULL,
STARTDATE DATE,
CLASSCODE VARCHAR2(4),
RISKCODE VARCHAR2(4),
COMCODE VARCHAR2(10) NOT NULL,
REINSMODE VARCHAR2(3) NOT NULL,
TREATYNO VARCHAR2(10) NOT NULL,
TREATYSECTION VARCHAR2(12),
SHARERATE NUMBER(9,6),
CURRENCY VARCHAR2(3),
REAMOUNT NUMBER(14,2),
REPREMIUM NUMBER(14,2),
EXCHRATECNY NUMBER(12,8),
ACCPAYDATE DATE NOT NULL,
TREATYFLAG VARCHAR2(1) NOT NULL,
PAYDATE DATE NOT NULL,
STATDATE DATE,
CONSTRAINT PK_MID_R_REPOLICYSHARE PRIMARY KEY (REPOLICYNO,
COMCODE, TREATYNO, ACCPAYDATE, PAYDATE, TREATYFLAG,
CURRENCY)
);
由建表语句我们能看出此表的所因为复合索引,并且由REPOLICYNO, COMCODE, TREATYNO, ACCPAYDATE, PAYDATE, TREATYFLAG, CURRENCY等列构成。
当where条件包含REPOLICYNO, COMCODE, TREATYNO列时。使用的是索引查询。
SELECT POLICYNO
FROM REPOLICYSHARE
WHERE REPOLICYNO = 'PO0520062458001329'
AND COMCODE = '2458800605'
AND TREATYNO = 'OP2006ZL';
当where条件包含COMCODE, TREATYNO列时。使用的是全表扫描查询。
SELECT POLICYNO
FROM REPOLICYSHARE
WHERE COMCODE = '2458800605'
AND TREATYNO = 'OP2006ZL';
为什么同样是部分列,但查询形式却不一样呢?

ToadDuserSinMySqleFeffectially, 다음에 따르면, 다음 사항을 따르십시오

toaddanewuser와 함께 complexpermissionsinmysql, followthesesteps : 1) createShereuser'NewUser '@'localhost'Identifiedby'pa ssword ';. 2) grantreadaccesstoalltablesin'mydatabase'withgrantselectonmydatabase.to'newuser'@'localhost';. 3) GrantWriteAccessto '

MySQL의 문자열 데이터 유형에는 char, varchar, binary, varbinary, blob 및 텍스트가 포함됩니다. 콜라이트는 문자열의 비교와 분류를 결정합니다. 1. 차량은 고정 길이 스트링에 적합하고 Varchar는 가변 길이 스트링에 적합합니다. 2. 이진 및 바이너리는 이진 데이터에 사용되며 Blob 및 텍스트는 큰 객체 데이터에 사용됩니다. 3. UTF8MB4_UNICODE_CI와 같은 정렬 규칙은 상류 및 소문자를 무시하며 사용자 이름에 적합합니다. UTF8MB4_BIN은 사례에 민감하며 정확한 비교가 필요한 필드에 적합합니다.

가장 좋은 mysqlvarchar 열 길이 선택은 데이터 분석을 기반으로하고, 향후 성장을 고려하고, 성능 영향을 평가하고, 문자 세트 요구 사항을 기반으로해야합니다. 1) 일반적인 길이를 결정하기 위해 데이터를 분석합니다. 2) 미래 확장 공간을 예약하십시오. 3) 성능에 대한 큰 길이의 영향에주의를 기울이십시오. 4) 문자 세트가 스토리지에 미치는 영향을 고려하십시오. 이러한 단계를 통해 데이터베이스의 효율성과 확장 성을 최적화 할 수 있습니다.

mysqlblobshavelimits : tinyblob (255bodes), blob (65,535 bytes), mediumblob (16,777,215 bctes), andlongblob (4,294,967,295 Bytes) .tousebl obseffectical : 1) 고려 사항을 고려합니다

MySQL에서 사용자 생성을 자동화하기위한 최고의 도구 및 기술은 다음과 같습니다. 1. MySQLworkBench, 중소형 환경에 적합하고 사용하기 쉽지만 자원 소비가 높습니다. 2. 다중 서버 환경에 적합한 Ansible, 간단하지만 가파른 학습 곡선; 3. 사용자 정의 파이썬 스크립트, 유연하지만 스크립트 보안을 보장해야합니다. 4. 꼭두각시와 요리사는 대규모 환경에 적합하며 복잡하지만 확장 가능합니다. 선택할 때 척도, 학습 곡선 및 통합 요구를 고려해야합니다.

예, youcansearchinsideablobinmysqlusingspecifictechniques.1) converttheblobtoautf-8stringwithConvertFunctionandSearchusing


핫 AI 도구

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

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

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

Atom Editor Mac 버전 다운로드
가장 인기 있는 오픈 소스 편집기

SublimeText3 영어 버전
권장 사항: Win 버전, 코드 프롬프트 지원!

Eclipse용 SAP NetWeaver 서버 어댑터
Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.

PhpStorm 맥 버전
최신(2018.2.1) 전문 PHP 통합 개발 도구

MinGW - Windows용 미니멀리스트 GNU
이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.