sequence的MAXVALUE、NOMAXVALUE和CYCLE、NOCYCLE参数
Oracle的sequence通常可以用来作自增列,例如主键,因为他可以自动累加并且唯一。创建sequence时有几个参数,MAXVALUE、MINVALUE、CYCLE、NOCYCLE、NOMAXVALUE等,这几个参数我们日常使用的时候可能不会太在意,但有些细节问题碰到的时候就需要明确下。 1、
Oracle的sequence通常可以用来作自增列,例如主键,因为他可以自动累加并且唯一。创建sequence时有几个参数,MAXVALUE、MINVALUE、CYCLE、NOCYCLE、NOMAXVALUE等,这几个参数我们日常使用的时候可能不会太在意,但有些细节问题碰到的时候就需要明确下。
1、未定义NOCYCLE,默认是NOCYCLE还是CYCLE?
CREATE SEQUENCE test_seq
start with 1
increment by 1
MAXVALUE 2
cache 20;
SELECT test_seq.nextval FROM DUAL;取值为1。
SELECT test_seq.nextval FROM DUAL;取值为2。
SELECT test_seq.nextval FROM DUAL;报错:ORA-08004: sequence TEST_SEQ.NEXTVAL exceeds MAXVALUE and cannot be instantiated,说明未指定的情况下,默认是NOCYCLE。
2、未定义MAXVALUE,默认是MAXVALUE还是NOMAXVALUE?
CREATE SEQUENCE tes_seq
start with 1
increment by 1
cache 20;
查看MAXVALUE取值是999999999999999999999999999,说明默认是MAXVALUE。
3、MAXVALUE最大值究竟是多少?
CREATE SEQUENCE tes_seq
start with 1
maxvalue 29个9
increment by 1
cache 20;
提示:ORA-04003:sequence parameter MAXVALUE exceeds maximum size allowed (28 digits)
说明最大允许28位。
创建了28位的MAXVALUE,并且设置CYCLE:
CREATE SEQUENCE test_seq
start with 9999999999999999999999999998
MAXVALUE 9999999999999999999999999999
increment by 1
CYCLE;
此时执行:SELECT test_seq. nextval FROM DUAL;,返回值是1E28,真正应是9999999999999999999999999998,
此时test_seq显示NEXT NUMBER是10000000000000000000000000000。
再执行一次SELECT test_seq. NEXTVAL FROM DUAL;,值还是1E28。但实际值是9999999999999999999999999999,下面例子可以证明,最大值是10的28次方。
再执行一次SELECT test_seq. nextval FROM DUAL;,此时值=1。,
CREATE SEQUENCE test_seq
start with 9999999999999999999999999999
MAXVALUE 10000000000000000000000000000
increment by 1
CYCLE;
SELECT test_seq. nextval FROM DUAL;返回9999999999999999999999999999,
再执行一次SELECT test_seq. nextval FROM DUAL;就会报ORA-08004错误。进一步说明最大值是28个9数字。
4、使用NOMAXVALUE就可以使用无限大值?
CREATE SEQUENCE test_seq
start with 1
NOMAXVALUE
increment by 1
cache 20;
此时test_seq显示MAX VALUE是999999999999999999999999999,27个9数字。
说明即使设置NOMAXVALUE,仍有最大值限制。
结论:
MAXVALUE最大值是28个9,用科学计数法将最大值记做1E28,换句话说,即使设置NOMAXVALUE,也是有这个最大值的。
NOCYCLE是默认值。

핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

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

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

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

상수는 변수라고도 하며 일단 정의되면 프로그램이 실행되는 동안 그 값이 변경되지 않습니다. 따라서 변수를 고정된 값을 참조하는 상수로 선언할 수 있습니다. 텍스트라고도 합니다. 상수는 Const 키워드를 사용하여 정의해야 합니다. 구문 C 프로그래밍 언어에서 사용되는 상수의 구문은 다음과 같습니다. - consttypeVariableName; (또는) consttype*VariableName; 다양한 유형의 상수 C 프로그래밍 언어에서 사용되는 다양한 유형의 상수는 다음과 같습니다. 정수 상수 - 예: 1,0 ,34, 4567 부동 소수점 상수 - 예: 0.0, 156.89, 23.456 8진수 및 16진수 상수 - 예: 16진수: 0x2a, 0xaa.. 8진수

VS Code 및 Visual Studio C++ IntelliSense는 특히 대규모 프로젝트에서 작업할 때 라이브러리를 선택하지 못할 수 있습니다. #Include<wx/wx.h> 위로 마우스를 가져가면 "소스 파일 'string.h'를 열 수 없습니다."("wx/wx.h"에 따라 다름)라는 오류 메시지가 표시되며, 자동 완성 기능이 응답하지 않는 경우도 있습니다. 이 문서에서는 VSCode 및 VSC++ IntelliSense가 작동하지 않거나 라이브러리를 추출하지 않는 경우 수행할 수 있는 작업을 살펴보겠습니다. 내 Intellisense가 C++에서 작동하지 않는 이유는 무엇입니까? 대용량 파일을 작업할 때 IntelliSense가 가끔

정수 배열 Arr[]을 입력으로 사용합니다. 목표는 재귀적 방법을 사용하여 배열에서 가장 큰 요소와 가장 작은 요소를 찾는 것입니다. 재귀를 사용하고 있으므로 길이 = 1에 도달할 때까지 전체 배열을 반복한 다음 기본 사례를 구성하는 A[0]을 반환합니다. 그렇지 않은 경우 현재 요소는 현재 최소값 또는 최대값과 비교되고 해당 값은 후속 요소에 대해 반복적으로 업데이트됩니다. 이에 대한 다양한 입력 및 출력 시나리오를 살펴보겠습니다. −Input −Arr={12,67,99,76,32} Output −배열의 최대값: 99 설명 &mi

오류 코드 8C230002로 인해 Xbox에서 콘텐츠를 구매하거나 시청할 수 없습니까? 일부 사용자가 본체에서 콘텐츠를 구매하거나 시청하려고 할 때 이 오류가 계속 발생합니다. 죄송합니다. Xbox 서비스에 문제가 있습니다. 나중에 다시 시도해 보세요. 이 문제에 대한 도움말을 보려면 www.xbox.com/errorhelp를 방문하세요. 상태 코드: 8C230002 이 오류 코드는 일반적으로 일시적인 서버 또는 네트워크 문제로 인해 발생합니다. 그러나 계정의 개인 정보 보호 설정이나 자녀 보호 기능 등 다른 이유로 인해 특정 콘텐츠를 구매하거나 시청하지 못할 수도 있습니다. Xbox 오류 코드 8C230002 수정 Xbox 콘솔에서 콘텐츠를 보거나 구매하려고 할 때 오류 코드 8C가 나타나는 경우

숫자를 다양한 형식으로 표시하는 것은 학습의 기본 코딩 문제 중 하나입니다. 조건문 및 루프문과 같은 다양한 코딩 개념. 별표와 같은 특수 문자를 사용하여 삼각형이나 사각형을 인쇄하는 다양한 프로그램이 있습니다. 이 기사에서는 C++의 사각형처럼 나선형 형태로 숫자를 인쇄합니다. 행 수 n을 입력으로 사용하고 왼쪽 상단에서 시작하여 오른쪽, 아래, 왼쪽, 위, 다시 오른쪽 등으로 이동합니다. 숫자가 포함된 나선형 패턴 123456724252627282982340414243309223948494431102138474645321120373635343312191817161514

25일 뉴스에 따르면 중국동방항공은 성과보고회에서 C919 여객기의 최신 진행 상황을 공개했다. 회사에 따르면 COMAC과 체결한 C919 구매 계약은 2021년 3월 공식 발효됐으며, 첫 번째 C919 항공기는 2022년 말까지 인도됐다. 조만간 해당 항공기가 정식으로 실제 운항에 들어갈 것으로 예상된다. 중국동방항공은 상하이를 C919 상용 운항의 주요 기지로 삼아 2022년과 2023년 총 5대의 C919 여객기를 도입할 계획이다. 회사 측은 향후 도입 계획은 실제 운행 상황과 노선망 계획 등을 토대로 결정할 예정이라고 밝혔다. 편집자의 이해에 따르면 C919는 완전히 독립적인 지적 재산권을 보유하고 국제적으로 인정된 감항성 표준을 준수하는 중국의 차세대 글로벌 단일 통로 간선 여객기입니다. 해야 한다

C에서 void는 특정 유형이 없는 데이터를 의미하는 빈 유형을 나타내는 데 사용되는 특수 키워드입니다. C 언어에서 void는 주로 다음 세 가지 측면에서 사용됩니다. 함수 반환 유형은 void입니다. C 언어에서 함수는 int, float, char 등과 같은 다양한 반환 유형을 가질 수 있습니다. 그러나 함수가 어떤 값도 반환하지 않는 경우 반환 유형을 void로 설정할 수 있습니다. 이는 함수가 실행된 후에 특정 값을 반환하지 않음을 의미합니다. 예: voidhelloWorld()

프로그래밍 언어의 인기도를 측정하는 벤치마크 중 하나인 TIOBE 프로그래밍 커뮤니티 지수(TIOBE 프로그래밍 커뮤니티 지수)에 따르면 전 세계 엔지니어, 강좌, 벤더, 검색 엔진으로부터 데이터를 수집하여 평가합니다. 최근 2024년 1월 TIOBE 지수가 발표되었으며, 2023년 공식 프로그래밍 언어 순위가 발표되었습니다. C#이 TIOBE 2023 올해의 프로그래밍 언어상을 수상한 것은 C#이 23년 만에 처음입니다. TIOBE의 공식 보도 자료에 따르면 C#은 20년 넘게 상위 10위 안에 들었으며 이제 4대 언어를 따라잡으며 1년 만에 가장 큰 성장(+1.43%)을 달성한 프로그래밍 언어가 되었습니다. 이 상을 받는 것은 당연한 일입니다. 2위는 스크래치(+0.83%)와 포트란(+0)입니다.
