테이블에 삽입 할 값은 다음에 따른 대상 열의 데이터 유형 단계.
값 저장 유형 변환
대상과 정확히 일치하는지 확인하십시오.
그렇지 않으면 표현식을 대상으로 변환하십시오 유형. 등록 된 캐스트가 있으면 성공합니다 두 유형 사이. 표현이 알려지지 않은 유형 인 경우 문자 그대로, 문자 문자열의 내용은 대상 유형의 입력 변환 루틴.
대상이 고정 길이 유형 인 경우 (예 :char또는varchar선언 길이로) 그런 다음 대상 유형. 사이징 함수는 동일 한 함수입니다 이름으로 이름을 지정하여 첫 번째 인수를 가져옵니다. 그 유형이고 두 번째는 유형입니다정수및 동일한 유형을 반환합니다. 하나라면 열의 선언 된 길이를 전달하고 적용됩니다 두 번째 매개 변수로.
예 10-6.캐릭터스토리지 유형 변환
문자 (20)다음 진술은이를 보장합니다 저장된 값은 올바르게 크기가 있습니다.
생성 테이블 VV (v 문자 (20)); VV에 삽입 'ABC'|| 'def'; VV에서 V, 길이 (v)를 선택하십시오. V | 길이 ----------------------+-------- abcdef | 20 (1 행)
여기서 실제로 일어난 일은 두 사람이 알 수 없다는 것입니다. 리터럴이 해결됩니다텍스트기본적으로, 허용||운영자가 될 수 있습니다 로 해결텍스트연결. 그런 다음텍스트연산자 결과가 변환되었습니다 에게BPCHAR("Blank Padded Char",의 내부 이름캐릭터데이터 유형) 대상과 일치합니다 열 유형. (유형 이후텍스트andBPCHAR이진 호환입니다 변환은 실제 기능 호출을 삽입하지 않습니다.) 마지막으로, 마지막으로, 사이징 기능BPCHAR (BPCHAR, 정수)시스템 카탈로그에서 발견되어 연산자의 결과 및 저장된 열 길이. 이것 유형 별 함수 필요한 길이 점검을 수행합니다 패딩 공간 추가.