Database ( DB )/Database

SQL Server JDBC Driver(MSSQL)에서의 NVARCHAR, VARCHAR

노루아부지 2020. 10. 10. 14:11
반응형
SELECT *
FROM TB_USER
WHERE USER_NAME = '홍길동';

MSSQL은 DataType에 대한 우선순위가 있습니다.

nvarchar가 varchar보다 우선순위가 높기 때문에 index가 있는 varchar 컬럼에 nvarchar parameter가 mapping 된 경우, 우선순위에 따라 varchar 컬럼이 모두 nvarchar로 형변환이 일어난 후 조건을 비교하게 됩니다. 따라서 index가 무시됩니다.

예를 들어 아래와 같은 query가 있다고 가정합니다.

CREATE TABLE TB_USER (
    USER_ID varchar(64),
    USER_NAME varchar(64)
);

 

이 경우 WHERE 절을 만들기 위한 string 타입의 parameter는 SQL Server JDBC Driver에 의해 nvarchar로 mapping되어 query를 보내게 됩니다. 그럼 우선 순위에 의해 TB_USER 테이블의 모든 USER_NAME 컬럼들이 전부 nvarchar로 형변환이 일어납니다. 형변환이 일어나기 때문에 원래 설정된 index가 무시되는 것입니다.

이 문제를 해결하기 위해 JDBC URL에 sendStringParametersAsUnicode=false를 추가합니다.

 

spring:
  datasource:
    type: org.apache.tomcat.jdbc.pool.DataSource
    driverClassName: com.microsoft.sqlserver.jdbc.SQLServerDriver
    url: jdbc:sqlserver://localhost:1433;database=test;sendStringParametersAsUnicode=false

 

이 상황에서 한가지 의문이 생깁니다.

반대로, 컬럼의 nvarchar로 설정되어 있는 경우에는 어떻게 될까요?

정답은 "별 문제가 되지 않는다" 입니다.

컬럼이 nvarchar로 설정되어 있는 경우에는 parameter로 varchar가 넘어오더라도 우선순위에 의해 parameter에 형변환이 일어난 후 조건을 비교하기 때문에 index도 유지되고 성능에도 큰 문제가 되지 않는 것입니다.

 

[참고]

https://woowabros.github.io/study/2019/01/25/sqlserver-jdbc-driver.html

728x90
반응형
loading