* 질문 등록 시 다음의 내용을 꼭 기입하여 주세요.
Linux 64bit 등 | |
10.2 | |
10.2 |
|
java, php, odbc 등 입력 |
* CUBRID 응용 오류, SQL 오류 또는 SQL 튜닝 관련된 문의는 반드시 다음의 내용을 추가해 주세요. 비밀글이나 비밀 댓글도 가능합니다.
* 저희가 상황을 이해하고, 재현이 가능해야 알 수 있는 문제들이 많습니다. 가능한 정보/정황들을 부탁합니다.
에러 내용 및 재현 방법 | 재현 가능한 Source와 SQL |
관련 테이블(인덱스, 키정보 포함) 정보 | CUBRID 홈 디렉토리 아래 log 디렉토리 압축 |
-------------- 아래에 질문 사항을 기입해 주세요. ------------------------------------------------------------------------
utf-8로 데이터베이스를 구성했는데 컬럼의 데이터값이 byte를 측정하려면 어떻하요?
CREATE TABLE [test] (
[test1] CHARACTER VARYING (100) NOT NULL,
[test2] CHARACTER(100),
CONSTRAINT [testpp] PRIMARY KEY([test1])
)
COLLATE utf8_bin;
요렁게 구성하고 데이터를
test1 test2
1 - -
2 홍 홍
3 1 2
4 a A
5 홍길동12aA 홍길동12A
넣었을때 test1,2 의 바이트를 구하고 싶은데 어떻하죠?
SELECT BIT_LENGTH(test1), BIT_LENGTH(test2) FROM test;
BIT_LENGTH 함수를 쓰는게 맞나요?
값이 안맞는거 같아서요;;;
1 8 800
2 24 816
3 8 800
4 8 800
5 104 848
이렇게 나와서요
OCTET_LENGTH 함수를 사용하시면 됩니다.
위 데이터를 OCTET_LENGTH를 사용한 결과는 아래와 같습니다.
1 1 100
2 3 102
3 1 100
4 1 100
5 13 106
OCTET_LENGTH 함수는 해당 문자열의 길이를 바이트 단위로 나타내는 함수입니다. 8비트의 경우 1byte, 9비트의 경우 2byte로 나타나게 됩니다.
UTF-8 문자셋의 경우 한글 한 자당 3 byte, 영문과 숫자 그리고 기호는 한 자당 1 byte 를 차지합니다.
따라서 varchar 타입이 아닌 char 타입에서는 문자열의 길이가 고정되므로 위와 같은 결과가 나타나게 됩니다.
OCTET_LENGTH 함수에 대한 내용은 아래 메뉴얼을 참고해주시기 바랍니다.
https://www.cubrid.org/manual/ko/10.2/sql/function/string_fn.html#octet-length
감사합니다.