ThinkPHP에서 다중 데이터베이스 연결 문제를 해결하는 방법
이 글에서는 다중 데이터베이스 연결을 구현하는 ThinkPHP의 솔루션을 주로 소개합니다. 필요한 친구들은 참고하면 됩니다.
ThinkPHP가 다중 데이터 연결을 구현할 때, 데이터베이스가 동일한 서버에 있다면 정의만 하면 됩니다. 모델은 다음과 같습니다:
class MembersModel extends Model{ protected $trueTableName = 'members.members'; //数据库名.表名(包含了前缀) }
그런 다음 D("Members")와 같이 모델을 인스턴스화하고 일반 모델처럼 작동할 수 있습니다.
그러나 나중에 그의 데이터베이스가 두 개의 서로 다른 서버에 있다는 사실이 밝혀졌기 때문에 위의 방법은 작동하지 않았습니다.
이때, TP의 다중 데이터 연결 기능을 이용하셔야 합니다.
이와 관련하여 테스트 및 수정을 위해 공식 문서를 참조한 후 다음과 같은 해결책을 생각해 냈습니다.
다중 데이터 연결을 설정하려면 먼저 데이터베이스 구성 매개 변수를 구성해야 합니다. 하지만 다중 데이터베이스 연결을 설정할 때마다 데이터베이스 구성 배열을 생성하는 경우 구성 파일에 작성하는 것이 매우 번거롭습니다. 여기에 글을 쓰려면 여전히 약간의 기술이 필요합니다.
<?php $config= array( 'DEBUG_MODE'=>true, 'default_module'=>'Index', 'ROUTER_ON'=>TRUE, 'DATA_RESULT_TYPE'=>1, 'SHOW_RUN_TIME'=>true, // 运行时间显示 'SHOW_ADV_TIME'=>true, // 显示详细的运行时间 'SHOW_DB_TIMES'=>true, // 显示数据库查询和写入次数 'SHOW_CACHE_TIMES'=>true, // 显示缓存操作次数 'SHOW_USE_MEM'=>true, // 显示内存开销 'HTML_FILE_SUFFIX'=>'.shtml', // 默认静态文件后缀 'HTML_CACHE_ON' =>false, // 默认关闭静态缓存 'HTML_CACHE_TIME'=>60, // 静态缓存有效期 'HTML_READ_TYPE'=>1, // 静态缓存读取方式 0 readfile 1 redirect 'HTML_URL_SUFFIX'=>'.shtml', // 伪静态后缀设置 //默认数据库链接 'DB_TYPE'=>'mysql', 'DB_HOST'=>'localhost', 'DB_NAME'=>'news', 'DB_USER'=>'root', 'DB_PWD'=>'123', 'DB_PORT'=>'3306', 'DB_PREFIX'=>'news_', //我的第一个数据库连接 'DB_BBS'=>array( 'dbms' => 'mysql', 'username' => 'discuz', 'password' => '123', 'hostname' => 'localhost', 'hostport' => '3306', 'database' => 'discuz' ), //第二个数据库链接, 'DB_NEWS'=>array( 'dbms'=>'mysql', 'username'=>'root', 'password'=>'123', 'hostname'=>'localhost', 'hostport'=>'3306', 'database'=>'news' ) ); return $config; ?>
이제 C("DB_BBS") 및 C("DB_NEWS")를 사용하여 데이터베이스 구성 배열을 가져올 수 있습니다.
이제 구성이 완료되었으므로 모델을 인스턴스화해야 합니다. 우리 모델은 두 개의 서로 다른 데이터베이스 연결을 사용해야 하기 때문에 프로젝트 구성 파일은 기본적으로 UserModel.class.php와 같은 특정 테이블의 모델을 생성하는 경우
D("User" ); 현재 기본 데이터베이스에 사용자 테이블이 없으면 오류가 보고됩니다. 그래서 우리는 빈 모델을 만들 것입니다. 빈 모델은 테이블을 선택하지 않습니다.
빈 모델을 만드는 방법에는 두 가지가 있습니다. $dao=D(); 및 $dao=new Model(); 모두 괜찮습니다.
$dao=D();
모델을 인스턴스화한 후 데이터베이스 모델을 추가해야 합니다.
$dao->addConnect(C("DB_BBS"),1,true); $dao->addConnect(C("DB_NEWS"),2,true);
이 addConnect()에 대해 이야기해 보겠습니다. 이 함수의 프로토타입은 1.0.3과 1.0.4에서 다릅니다. .
1.0.3의 프로토타입은
boolean addConnect (mixed $config, mixed $linkNum, [boolean $eqType = true])
1.0.4의 프로토타입은 다음과 같습니다.
boolean addConnect (mixed $config, mixed $linkNum)
세 번째 매개변수가 누락되었습니다.
첫 번째 매개변수는 데이터베이스의 구성 배열이고, 두 번째 매개변수는 추가된 연결 번호입니다. 이 번호는 데이터베이스 연결 전환 시 연결의 일련번호로 지정되어야 합니다. 참고내장된 데이터베이스 연결 일련번호는 0이므로 추가 데이터베이스 연결 일련번호는 1부터 시작해야 합니다. 세 번째 매개변수는 두 데이터베이스가 동일한 연결이면 true입니다;
데이터베이스 연결을 추가한 후 , 언제든지 데이터베이스 연결을 전환할 수 있습니다. 예를 들어 DB_NEWS 데이터베이스를 사용하려면 다음과 같이 작성하면 됩니다.
$dao->switchConnect(2);
여기서만 데이터베이스 연결이 설정되고 테이블 선택이 없으므로 다음 테이블을 선택해야 합니다.
여기서 테이블 이름은 테이블 접두사에 테이블 이름을 더한 전체 이름입니다. 데이터베이스에 연결하기 위한 구성 배열에 접두사가 없기 때문입니다. 나는 그것이 정의 가능해야 한다고 생각하지만, 나는 모른다. 지금은 그게 다입니다.
$dao->table("cdb_members");
이후에는 이 모델을 일반 모델처럼 사용하시면 됩니다.
예를 들어, 전달된 ID를 가진 사용자의 모든 정보를 쿼리하고 싶습니다.
$map=array("id"=>$_GET["id"]); $res=$dao->find($map);
쿼리가 성공했는지 확인할 수 있습니다.
dump($res);
지금 DB_BBS의 데이터베이스 테이블을 사용하려면 연결을 다시 전환하세요.
$dao->switchConnect(2);
그런 다음 쿼리할 테이블을 선택하세요. 모델을 전환한 후에는 테이블을 다시 선택해야 합니다. 그렇지 않으면 오류가 발생합니다.
그러면 다시 일반 모델처럼 작동하시면 됩니다.
다음은 매뉴얼의 몇 가지 문제점을 지적합니다:
1. 다중 데이터베이스 연결을 인스턴스화할 때 비어 있지 않은 모델이 설정됩니다. (제가 잘못 쓴 것 같습니다.) 실수가 있을 수 있습니다.
2. addConnect()의 매개변수는 버전마다 다르며 매뉴얼에 기재되어 있지 않습니다.
3. 빈 모델을 설정한 후에는 테이블을 선택해야 합니다. 이 설명서에서.
위 사항을 고려하여 ThinkPHP 사용자는 다양한 버전에 따라 해당 조정을 수행할 수 있습니다.
위 내용은 이 글의 전체 내용입니다. 모든 분들의 학습에 도움이 되었으면 좋겠습니다. 더 많은 관련 내용은 PHP 중국어 홈페이지를 주목해주세요!
관련 권장사항:
ThinkPHP는 ajax와 유사한 공식 웹사이트 검색 기능을 구현합니다.
php 부동 소수점 문자열을 반올림하지 않고 가로채는 부동 방법
위 내용은 ThinkPHP에서 다중 데이터베이스 연결 문제를 해결하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

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

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

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

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

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

일부 애플리케이션이 제대로 작동하지 않는 회사의 보안 소프트웨어에 대한 문제 해결 및 솔루션. 많은 회사들이 내부 네트워크 보안을 보장하기 위해 보안 소프트웨어를 배포 할 것입니다. ...

Redis 메모리 급등에는 너무 큰 데이터 볼륨, 부적절한 데이터 구조 선택, 구성 문제 (예 : MaxMemory 설정이 너무 작은) 및 메모리 누출이 포함됩니다. 솔루션에는 만료 된 데이터 삭제, 압축 기술 사용, 적절한 구조 선택, 구성 매개 변수 조정, 코드의 메모리 누출 확인 및 메모리 사용을 정기적으로 모니터링합니다.

CentOS 시스템에 따라 Minio 설치를위한 권한 문제 및 솔루션 CentOS 환경에서 Minio를 배포 할 때 권한 문제가 일반적인 문제입니다. 이 기사는 Minio의 설치 및 구성을 원활하게 완료하는 데 도움이되는 몇 가지 일반적인 권한 문제와 해당 솔루션을 소개합니다. 기본 계정 및 비밀번호 수정 : 환경 변수를 설정하여 기본 사용자 이름과 암호를 수정할 수 있습니다. minio_root_user 및 minio_root_password. 수정 후 Minio 서비스를 다시 시작하면 적용됩니다. 버킷 액세스 권한 구성 : 버킷을 공개로 설정하면 디렉토리가 통과하여 보안 위험이 발생합니다. 버킷 액세스 정책을 사용자 정의하는 것이 좋습니다. Minio를 사용할 수 있습니다

다음 단계는 Navicat이 데이터베이스에 연결할 수없는 문제를 해결하는 데 사용될 수 있습니다. 서버 연결을 확인하고 서버가 실행되고 주소 및 포트가 올바르게 작동하는지 확인하고 방화벽에서 연결을 허용합니다. 로그인 정보를 확인하고 사용자 이름, 암호 및 권한이 올바른지 확인하십시오. 네트워크 연결을 확인하고 라우터 또는 방화벽 고장과 같은 네트워크 문제를 해결하십시오. 일부 서버에서 지원하지 않을 수있는 SSL 연결을 비활성화하십시오. Navicat 버전이 대상 데이터베이스와 호환되는지 확인하려면 데이터베이스 버전을 확인하십시오. 연결 시간 초과를 조정하고 원격 또는 느린 연결의 경우 연결 시간 초과를 늘리십시오. 다른 해결 방법, 위의 단계가 작동하지 않으면 소프트웨어를 다시 시작하거나 다른 연결 드라이버를 사용하거나 데이터베이스 관리자 또는 공식 Navicat 지원을 컨설팅 할 수 있습니다.

Phpmyadmin은 PHP 프로젝트에서 데이터베이스를 만드는 데 사용될 수 있습니다. 특정 단계는 다음과 같습니다. phpmyadmin에 로그인하고 "새"버튼을 클릭하십시오. 작성하려는 데이터베이스의 이름을 입력하고 MySQL 명명 규칙을 준수합니다. 문제를 피하기 위해 UTF-8과 같은 문자 세트를 설정하십시오.

Centos에서 Hadoop 분산 파일 시스템 (HDFS) 구성에 대한 일반적인 문제 및 솔루션 Centos에서 HadoophDFS 클러스터를 구축 할 때 일부 일반적인 잘못된 구성으로 인해 성능 저하, 데이터 손실이 발생할 수 있으며 심지어 클러스터조차 시작할 수 없습니다. 이 기사는 이러한 공통 문제와 이러한 함정을 피하고 HDFS 클러스터의 안정성과 효율적인 작동을 보장하는 데 도움이되는 솔루션을 요약합니다. 랙 인식 구성 오류 : 문제 : 랙-인식 정보가 올바르게 구성되지 않아 데이터 블록 복제본의 분포가 고르지 않고 네트워크로드가 증가합니다. 솔루션 : HDFS-Site.xml 파일에서 랙-인식 구성을 두 번 확인하고 HDFSDFSADMIN-PRINTTOPO를 사용하십시오.

VS 코드는 Windows 8에서 실행될 수 있지만 경험은 크지 않을 수 있습니다. 먼저 시스템이 최신 패치로 업데이트되었는지 확인한 다음 시스템 아키텍처와 일치하는 VS 코드 설치 패키지를 다운로드하여 프롬프트대로 설치하십시오. 설치 후 일부 확장은 Windows 8과 호환되지 않을 수 있으며 대체 확장을 찾거나 가상 시스템에서 새로운 Windows 시스템을 사용해야합니다. 필요한 연장을 설치하여 제대로 작동하는지 확인하십시오. Windows 8에서는 VS 코드가 가능하지만 더 나은 개발 경험과 보안을 위해 새로운 Windows 시스템으로 업그레이드하는 것이 좋습니다.

Redis 메모리 조각화는 할당 된 메모리에 재 할당 할 수없는 작은 자유 영역의 존재를 말합니다. 대처 전략에는 다음이 포함됩니다. REDIS를 다시 시작하십시오 : 메모리를 완전히 지우지 만 인터럽트 서비스. 데이터 구조 최적화 : Redis에 더 적합한 구조를 사용하여 메모리 할당 및 릴리스 수를 줄입니다. 구성 매개 변수 조정 : 정책을 사용하여 최근에 가장 적게 사용 된 키 값 쌍을 제거하십시오. 지속 메커니즘 사용 : 데이터를 정기적으로 백업하고 Redis를 다시 시작하여 조각을 정리하십시오. 메모리 사용 모니터링 : 적시에 문제를 발견하고 조치를 취하십시오.
