>데이터 베이스 >MySQL 튜토리얼 >mysql에서 크기 차이를 설정하는 방법

mysql에서 크기 차이를 설정하는 방법

PHPz
PHPz원래의
2023-04-19 17:25:345997검색

MySQL 데이터베이스는 웹 애플리케이션에서 데이터를 저장하고 액세스하는 데 일반적으로 사용되는 관계형 데이터베이스 관리 시스템입니다. MySQL의 데이터 테이블은 대소문자를 구분하지 않습니다. 즉, 쿼리할 때 대소문자를 구분하지 않습니다. 그러나 어떤 경우에는 MySQL에서 대소문자를 구분해야 하며, 이 경우 해당 설정을 지정해야 합니다. 이 기사에서는 MySQL에서 대소문자 구분을 설정하는 방법을 소개합니다.

1. MySQL의 대소문자 구분 원칙

MySQL에서는 이름은 언어의 단어나 구문이 아닌 문자로만 간주됩니다. 따라서 MySQL은 이름 간의 차이를 확인하기 위해 대소문자를 사용하지 않습니다. 예를 들어 MySQL은 "table1"과 "Table1"을 동일한 이름으로 처리합니다.

2. MySQL 대소문자 구분 설정

  1. my.cnf 구성 파일에 설정

my.cnf 구성 파일을 엽니다. 존재하지 않는 경우 새 파일을 만듭니다. 파일에 다음 코드를 추가합니다.

[mysqld]
lower_case_table_names=1

파일을 저장하고 MySQL 서버를 다시 시작합니다. lower_case_table_names를 1로 설정하여 MySQL이 대소문자 구분을 적용하도록 할 수 있습니다. 0으로 설정하면 MySQL은 대소문자를 구분하지 않으며 기본값은 0입니다.

  1. 명령줄에서 설정

MySQL 구성 파일을 수정할 권한이 없는 사용자의 경우 MySQL 명령줄에서 설정할 수 있습니다. 명령줄에서 다음 명령을 사용하세요.

SET GLOBAL lower_case_table_names=1;

이렇게 하면 MySQL 서버에서 전역적으로 lower_case_table_names 매개변수가 1로 설정됩니다. 이 설정은 MySQL 서버를 다시 시작해도 유지됩니다.

다음을 사용하여 현재 세션에서 설정할 수도 있습니다.

SET SESSION lower_case_table_names=1;

이렇게 하면 현재 세션에서 lower_case_table_names 매개변수가 1로 설정됩니다. 이 설정은 현재 세션이 끝나면 만료됩니다.

3. 참고

  1. lower_case_table_names=1 매개변수를 사용하면 민감한 테이블 이름의 대소문자가 소문자로 변환됩니다. 두 테이블이 이름은 같지만 대소문자를 다르게 작성한 경우 lower_case_table_names=1이면 동일한 테이블이 됩니다. 따라서 이 매개변수를 사용할 때는 테이블 이름을 신중하게 선택해야 합니다.
  2. lower_case_table_names=1을 사용하면 utf8_bin과 같은 대/소문자를 구분하는 이진이 아닌 정렬 또는 조회 규칙을 사용할 수 없습니다. lower_case_table_names=1은 모든 문자를 소문자로 변환하여 대소문자 구분 정렬 또는 검색 규칙이 작동하지 않기 때문입니다.
  3. lower_case_table_names=1이면 대소문자 구분 문자 집합 기능을 사용할 수 없습니다. 예를 들어 latin1_cs 또는 utf8_cs 문자 집합에서 cs는 대소문자 구분을 나타내지만 lower_case_table_names=1은 모든 문자를 소문자로 강제 변환하므로 대소문자 구분 규칙이 작동하지 않습니다.

4. 요약

MySQL 데이터베이스의 기본 설정은 대소문자를 구분하지 않습니다. 그러나 쿼리할 때 대소문자를 구분해야 하는 경우 my.cnf 구성 파일에서 lower_case_table_names를 1로 설정하거나 MySQL 명령줄에서 SET 문을 사용할 수 있습니다. 그러나 lower_case_table_names=1 사용에는 몇 가지 제한 사항이 있으며, 이는 테이블 이름이나 문자 집합을 주의 깊게 선택하지 않으면 문제가 발생할 수 있다는 점에 유의해야 합니다. 그러므로 주의해서 사용해야 합니다.

위 내용은 mysql에서 크기 차이를 설정하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.