mysql 대소문자 구분 구성 문제 해석
1.mysql 대소문자 구분 구성
mysql 대소문자 구분 구성과 관련된 두 개의 매개변수인 lower_case_file_system 및 lower_case_table_names.
mysql의 현재 대소문자 구분 구성 보기
show global variables like '%lower_case%';+------------------------+-------+| Variable_name | Value | +------------------------+-------+| lower_case_file_system | ON | | lower_case_table_names | 0 |+------------------------+-------+
lower_case_file_system
현재 시스템 파일이 대소문자를 구분하는지 여부를 나타냅니다. 이는 수정할 수 없는 읽기 전용 매개변수입니다.
ON 대소문자 구분 안함
OFF 대소문자 구분
lower_case_table_names
테이블 이름이 대소문자를 구분하고 수정 가능한지 여부를 나타냅니다.
lower_case_table_names = 0이면 mysql은 테이블 이름을 기반으로 직접 작동하며 대소문자를 구분합니다.
lower_case_table_names = 1이면 mysql은 작업을 수행하기 전에 먼저 테이블 이름을 소문자로 변환합니다.
lower_case_table_names 값 설정
my.cnf 파일을 열고 다음 명령문을 추가한 후 다시 시작하세요.
lower_case_table_names = 0 或 lower_case_table_names = 1
2. lower_case_table_names가 0이고 1일 때 다양한 상황을 테스트합니다.
테이블 사용자 생성
CREATE TABLE `user` ( `id` int(11) unsigned NOT NULL AUTO_INCREMENT, `name` varchar(20) NOT NULL, PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
1. lower_case_table_names = 0
테이블 이름은 생성 당시의 대소문자와 일치합니다
으레 ee테이블 이름은 생성 당시의 대소문자와 일치하지 않습니다
select count(*) from user; +----------+| count(*) | +----------+| 0 | +----------+
lower_case_table_names=0인 경우 테이블 이름은 대소문자를 구분합니다.
2. lower_case_table_names = 1로 설정
테이블 이름이 생성 당시의 대소문자와 일치하지 않습니다
select count(*) from User;ERROR 1146 (42S02): Table 'user.User' doesn't exist
테이블 이름이 생성 당시의 대소문자와 일치하지 않습니다
select count(*) from user; +----------+| count(*) | +----------+| 0 | +----------+
lower_case_table_names=1, 테이블 이름은 대소문자를 구분하지 않습니다.
3. lower_case_table_names=1로 설정하면 lower_case_table_names=0일 때 원래 생성된 테이블이 존재하지 않는 문제에 대한 해결 방법
lower_case_table_names=0인 경우 대소문자를 혼합하여 테이블 이름을 만듭니다. lower_case_table_names=1 이후에는 원래 생성된 테이블을 사용할 때 존재하지 않는다는 메시지가 표시됩니다.
Demonstration
첫번째 설정 lower_case_table_names=0
Create table User (대소문자 혼합)
select count(*) from user; +----------+| count(*) | +----------+| 0 | +----------+
그런 다음 lower_case_table_names=1
설정 테이블 이름이 대문자인지 소문자인지 여부 , 둘 다 프롬프트 테이블이 존재하지 않습니다
CREATE TABLE `User` ( `id` int(11) unsigned NOT NULL AUTO_INCREMENT, `name` varchar(20) NOT NULL, PRIMARY KEY (`id`)) ENGINE=InnoDB DEFAULT CHARSET=utf8;show tables; +----------------+| Tables_in_user | +----------------+| User | +----------------+
lower_case_table_names=1 일 때 작업 전 테이블 이름이 소문자로 변환되기 때문에 파일에 소문자 테이블 이름 파일이 전혀 없어 에러가 발생합니다.
해결 방법:
lower_case_table_names을 0에서 1로 수정하려면 먼저 기존 데이터 테이블의 테이블 이름을 처리하고 모든 데이터베이스의 테이블 이름을 먼저 소문자로 변경한 후 마지막으로 설정해야 합니다. lower_case_table_names는 1입니다. 그렇지 않으면 위의 문제가 발생합니다.
요약:
운영 체제가 다르면 대소문자 구분이 일관되지 않습니다. 개발할 때 대소문자 구분 원칙에 따라 개발해야 개발된 프로그램이 다양한 운영 체제와 호환될 수 있습니다. 따라서 개발 및 테스트 환경에서는 lower_case_table_names 값을 0으로 설정하여 개발 시 코드의 대소문자 구분을 엄격하게 제어하고 코드의 호환성 및 엄격성을 향상시키는 것이 좋습니다.
이 글에서는 MySQL의 대소문자 구분 구성 문제에 대해 설명합니다. 더 많은 관련 내용을 보려면 PHP 중국어 웹사이트를 참고하세요.
관련 권장 사항:
PHP를 사용하여 배열을 병합하고 키 값을 유지하는 방법
phpcurl을 사용하여 다중 프로세스 다운로드 파일 클래스를 구현하는 방법
php를 사용하여 여부를 결정하는 방법 로컬 및 원격 파일이 존재합니다
위 내용은 mysql 대소문자 구분 구성 문제 해석의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undress AI Tool
무료로 이미지를 벗다

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

MySQL에 모든 데이터베이스를 표시하려면 ShowDatabases 명령을 사용해야합니다. 1. MySQL 서버에 로그인 한 후 ShowDatabase를 실행할 수 있습니다. 현재 사용자가 액세스 할 권한이있는 모든 데이터베이스를 나열하도록 명령. 2. Information_Schema, MySQL, Performance_Schema 및 SYS와 같은 시스템 데이터베이스는 기본적으로 존재하지만 권한이 부족한 사용자는이를 볼 수 없을 수 있습니다. 3. SelectSchema_namefrominformation_schema.schemata를 통해 데이터베이스를 쿼리하고 필터링 할 수도 있습니다. 예를 들어, 사용자가 만든 데이터베이스 만 표시하려면 시스템 데이터베이스를 제외합니다. 사용하십시오

기존 테이블에 기본 키를 추가하려면 AddPrimarykey 절을 사용하여 Altertable 문을 사용하십시오. 1. 대상 열에 널 값이없고 복제가 없으며 NOTNULL로 정의되어 있는지 확인하십시오. 2. 단일 열차 기본 키 구문은 Altertable 테이블 이름 AddPrimaryKey (열 이름)입니다. 3. 멀티 컬럼 조합 기본 키 구문은 Altertable 테이블 이름 AddPrimaryKey (열 1, 열 2)입니다. 4. 열에서 NULL을 허용하는 경우 먼저 NOTNULL을 설정하도록 수정을 실행해야합니다. 5. 각 테이블에는 하나의 기본 키만이있을 수 있으며 추가하기 전에 기존 기본 키를 삭제해야합니다. 6. 직접 늘려야하는 경우 modify를 사용하여 auto_increment를 설정할 수 있습니다. 작동하기 전에 데이터를 확인하십시오

MySQL 서비스가 실행 중인지 확인하고 sudosystemctlstatusmysql을 사용하여 확인하고 시작하십시오. 2. 원격 연결을 허용하고 서비스를 다시 시작하기 위해 BAND-ADDRESS가 0.0.0.0으로 설정되어 있는지 확인하십시오. 3. 3306 포트가 열려 있는지 확인하고 포트를 허용하도록 방화벽 규칙을 확인하고 구성하십시오. 4. "AccessDenied"오류의 경우 사용자 이름, 비밀번호 및 호스트 이름을 확인한 다음 MySQL에 로그인하여 MySQL.user 테이블을 쿼리하여 권한을 확인해야합니다. 필요한 경우 사용자를 생성하거나 업데이트하여 'Your_user'@'%'사용과 같은 승인; 5. Caching_sha2_password로 인해 인증이 손실 된 경우

mysqldump를 사용하는 것이 MySQL 데이터베이스를 백업하는 가장 일반적이고 효과적인 방법입니다. 테이블 구조 및 데이터가 포함 된 SQL 스크립트를 생성 할 수 있습니다. 1. 기본 구문은 다음과 같습니다. mysqldump-u [user name] -p [database name]> backup_file.sql입니다. 실행 후 암호를 입력하여 백업 파일을 생성하십시오. 2.-databases 옵션으로 여러 데이터베이스를 백업 옵션 : mysqldump-uroot-p-- databasesdb1db2> multip_dbs_backup.sql. 3. all-databases : mysqldump-uroot-p를 사용하여 모든 데이터베이스를 백업합니다

b-treeindexesarebestformostphpapplications, asysupportequalityandrangequeries, 분류, andareidealforcolumnsusedinwhere, ororderbyclauses;

UnionleMovesDuplicates는 Duplicates; 1.unionperformsDeduplicationBysorting 및 ComcomparingRows, ReturnOnlyUniqueresults, whathitSlowerOnlargedAtasets;

Group_Concat () 함수에서 분리기 키워드를 사용하여 분리기를 사용자 정의 할 수 있습니다. 1. 분리기를 사용하여 구분 기호와 같은 사용자 정의 분리기를 지정하십시오. '분리기는 세미콜론 및 플러스 공간으로 변경할 수 있습니다. 2. 일반적인 예제에는 파이프 문자 '|', space '', 라인 브레이크 문자 '\ n'또는 사용자 정의 문자열 '->'가 포함됩니다. 3. 분리기는 문자열 리터럴 또는 표현식이어야하며 결과 길이는 Group_Concat_Max_Len 변수에 의해 제한되며 SetSessionGroup_CONCAT_MAX_LEN = 100000으로 조정할 수 있습니다. 4. 분리기는 선택 사항입니다

Locktables를 사용하여 수동으로 테이블을 잠글 수 있습니다. 읽기 잠금은 여러 세션을 읽을 수 있지만 쓸 수는 없습니다. Write Lock은 현재 세션에 대한 독점 읽기 및 쓰기 권한을 제공하며 다른 세션은 읽고 쓸 수 없습니다. 2. 잠금은 현재 연결을위한 것입니다. STARTTRANSACTION 및 기타 명령의 실행은 암시 적으로 잠금을 해제합니다. 잠금 후 잠긴 테이블에만 액세스 할 수 있습니다. 3. MyISAM 테이블 유지 보수 및 데이터 백업과 같은 특정 시나리오에서만 사용하십시오. InnoDB는 성능 문제를 피하기 위해 Select ... ForupDate와 같은 트랜잭션 및로드 레벨 잠금을 사용하는 데 우선 순위를 부여해야합니다. 4. 작업이 완료된 후 잠금 해제 가능성을 명시 적으로 릴리스해야합니다. 그렇지 않으면 자원 막힘이 발생할 수 있습니다.
