Background Image

FORUM

조회 수 1706 추천 수 0 댓글 1
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄

* 질문 등록 시 다음의 내용을 꼭 기입하여 주세요.
OS
Linux 64bit
CUBRID Ver.
CUBRID 10.1 (10.1.0.7663-1ca0ab8) (64bit release build for Linux) (Jul 12 2017 21:54:48)
CUBRID TOOL Ver.
[도움말]-[버전정보] 확인
응용 환경(API)
php


-------------- 아래에 질문 사항을 기입해 주세요. ------------------------------------------------------------------------


안녕하세요. XpressEngine 3.0 에 큐브리드를 붙여서 홈페이지를 개발하고 있습니다.

https://github.com/xpressengine/laravel-cubrid 드라이버를 이용해 PHP 7에서 구축하고 있는데요.


영문 대소문자 검색할 때 문제가 되어 드라이버에서 like 검색이 들어오는 경우 컬럼에 UPPER로 처리하도록 하고 있습니다.

.. (UPPER(`title`) like '%FACTORY%' or UPPER(`pure_content`) like '%FACTORY%') ...


이렇게 해서 대소문자를 해결했는데요. 이제 한글 검색어가 들어오는 경우 문제가 되고 있습니다.

.. (UPPER(`title`) like '%기업%' or UPPER(`pure_content`) like '%기업%') ..

위와 같이 컬럼에 UPPER를 한 경우 한글 검색이 안되는데요.


이 문제를 해결하기 위한 큐브리드 설정이 있는지.. 혹은 제가 데이터 처리할 때 주의해야할 사항이 있는건지 질문 드립니다.


  • ?
    bikehee 2017.11.16 19:05
    CUBRID사용하는 유저입니다.

    https://www.cubrid.org/manual/ko/8.4.4/sql/function/condition_fn.html?highlight=upper#like
    UTF-8과 같은 멀티바이트 문자셋 환경에서 입력된 데이터에 대해서는 LIKE 검색 결과가 정상적이지 않을 수 있다. 이는 문자셋에 따라 문자열 비교 연산을 수행하는 바이트 단위가 다르기 때문이며, 1바이트 단위로 문자열 비교를 수행하도록 하는 파라미터(single_byte_compare=yes)를 cubrid.conf 파일에 추가한 후 DB를 재가동하면 정상적인 검색 결과를 얻을 수 있다.

    cubrid.conf에 single_byte_compare=yes 설정넣고 재시작하면 검색 잘될것 같습니다~

    그리고 대소문자의 경우엔 upper대신 regexp을 사용해도 될것 같습니다.
    ====
    create table foo (name varchar(20));
    csql> select * from foo;
    name
    ======================
    '가'
    '가나'
    '나가'
    '가나다'
    '가다'
    'a'
    'aA'
    'AB'
    'bb'
    'bB'

    --한글검색
    select * from foo where upper(name) like '%나%'
    name
    ======================
    '가나'
    '나가'
    '가나다'

    --대소문자구분없이
    csql> select * from foo where name regexp '[A]';
    name
    ======================
    'a'
    'aA'
    'AB'

List of Articles
번호 제목 글쓴이 날짜 조회 수
공지 CUBRID 사용자를 위한 DBeaver 도구 출시 안내 admin 2024.04.23 51
공지 SQLGate for CUBRID 영구 무료 라이선스 제공 file admin 2020.04.09 4458
3854 8.4.4 charset. Collation 확인 방법 네오랜덤 2023.05.24 188
3853 8.4.4버젼 charset 확인 3 네오랜덤 2023.05.23 193
3852 쿼리 속도 차이 질문 1 하얀미스 2023.05.18 143
3851 spring boot 에서 HikariPool-1 - Driver does not support get/set network timeout for connections. (java.lang.UnsupportedOperationException) 질문 드립니다. 3 kjaminam 2023.05.18 785
3850 cci 프로그래밍에서 DB LINK 관련 문의 4 jjune1206 2023.05.18 131
3849 큐브리드 매니저 실행이 오류 1 file 청주시청 2023.05.18 101
3848 ddl 추출 1 네오랜덤 2023.05.17 105
3847 하나의 쿼리에서 복수 테이블 업데이트 방법 문의 4 도담도담 2023.05.17 136
3846 cubrid driver 설치 문의 1 고구망구망 2023.05.08 438
3845 큐브리드 매니저 접속 이 안됩니다. 확인 요청 드립니다. 1 뿡이 2023.04.28 128
3844 Fk값 가져오기 2 file 네오랜덤 2023.04.24 166
3843 서버 메모리 교체 및 ha 상 데이터 삭제 절차 1 레피엘 2023.04.20 113
3842 java stored procedure 에 loadjava 로 jar 파일 로드 시 java.lang.ClassNotFoundException 에러 문의 3 개미가불쌍해 2023.04.18 147
3841 Cubrid stored procedure 스케쥴 등록 형식 2 Roy 2023.04.17 112
3840 암호화 함수 MDB_ENC 질문입니다 1 BE-DEV 2023.04.17 82
3839 auto_increment 추가 방법 문의 1 부패방지운영팀 2023.04.14 265
3838 CUBRID 사용자 계정 생성 관련 문의 1 몽키스패너 2023.04.14 132
3837 order by 이후 rownum이 의도와 다르게 찍힙니다. 2 바보똥개 2023.04.14 143
3836 백업 및 복구 시 cubrid 버전 간 호환 문의 1 플레이어블 2023.04.13 71
3835 centos8에서 쉘스크립트 실행시 csql: command not found 오류 발생 6 kjn4345 2023.04.13 180
Board Pagination Prev 1 ... 3 4 5 6 7 8 9 10 11 12 ... 200 Next
/ 200

Contact Cubrid

대표전화 070-4077-2110 / 기술문의 070-4077-2113 / 영업문의 070-4077-2112 / Email. contact_at_cubrid.com
Contact Sales