찾다
PHP 프레임워크ThinkPHP데이터베이스에 연결하기 위한 ThinkPHP 데이터베이스 작업

다음 튜토리얼 칼럼인 thinkphp에서는 ThinkPHP 데이터베이스 작업을 통해 데이터베이스를 연결하는 방법을 소개하겠습니다. 필요한 친구들에게 도움이 되길 바랍니다!

 ThinkPHP에는 다양한 데이터베이스 작업을 캡슐화하는 추상 데이터베이스 액세스 계층이 내장되어 있습니다. 다른 데이터베이스에 대한 다른 코드 및 기본 구현을 작성하지 않고도 작동하려면 공용 Db 클래스만 사용하면 됩니다. 처리할 드라이버. PDO 방법을 사용하면 현재 Mysql, SqlServer, PgSQL, Sqlite 및 기타 데이터베이스에 대한 지원이 포함됩니다.

애플리케이션이 데이터베이스를 사용해야 하는 경우 데이터베이스 연결 정보를 구성해야 합니다. 데이터베이스 구성 파일을 정의하는 방법에는 여러 가지가 있습니다.

  • 1. 구성 파일 정의
  • 2. 메소드 구성
  • 3. 모델 클래스 정의
  • 구성 매개변수 참조

1. 구성 파일 정의

module 다음 구성 매개변수를 Database.php 디렉토리 아래에 추가하십시오.

return [
  // 数据库类型  'type' => 'mysql',
  // 数据库连接DSN配置  'dsn' => '',
  // 服务器地址  'hostname' => '127.0.0.1',
  // 数据库名  'database' => 'thinkphp',
  // 数据库用户名  'username' => 'root',
  // 数据库密码  'password' => '',
  // 数据库连接端口  'hostport' => '',
  // 数据库连接参数  'params' => [],
  // 数据库编码默认采用utf8  'charset' => 'utf8',
  // 数据库表前缀  'prefix' => 'think_',
  // 数据库调试模式  'debug' => false,
  // 数据库部署方式:0 集中式(单一服务器),1 分布式(主从服务器)  'deploy' => 0,
  // 数据库读写是否分离 主从式有效  'rw_separate' => false,
  // 读写分离后 主服务器数量  'master_num' => 1,
  // 指定从服务器序号  'slave_no' => '',
  // 是否严格检查字段是否存在  'fields_strict' => true,];
type 매개변수는 전체 네임스페이스 정의를 지원합니다. 네임스페이스 정의가 없으면 기본적으로 thinkdbconnector가 네임스페이스로 사용됩니다. 다음과 같이 구성할 수 있습니다.

// 数据库类型
'type' => '\org\db\Mysql',
데이터베이스 커넥터가 기본 thinkdbconnectorMysql 대신 orgdbMysql 클래스를 데이터베이스 연결 드라이버로 사용함을 나타냅니다.


각 모듈은 독립적인 데이터베이스 연결 매개변수를 설정할 수 있으며 동일한 구성 매개변수를 반복적으로 설정할 필요가 없습니다. 예를 들어 관리 모듈의 Database.php 구성 파일에서 다음을 정의할 수 있습니다.

return [
  // 服务器地址  
  'hostname' => '192.168.1.100',
  // 数据库名  
  'database' => 'admin',];
는 데이터베이스가 admin 모듈의 주소는 192.168.1.100으로 변경되고, 데이터베이스 이름은 admin으로 변경되며, 기타 연결 매개변수는 애플리케이션의 Database.php 구성과 동일합니다.


V5.0.6+ 버전 시작, 기본적으로 꺼져 있는 MySQL의 연결 해제 및 재연결 메커니즘을 지원합니다. 필요한 경우 데이터베이스 구성 파일에 추가하세요.

// 开启断线重连
'break_reconnect' => true,

연결 매개변수

를 추가할 수 있습니다. 다른 연결에는 데이터베이스 연결 매개변수가 필요합니다(특정 연결 매개변수에 대해서는 PHP 매뉴얼을 참조하십시오). 내장 매개변수에는 다음이 포함됩니다.

PDO::ATTR_CASE => PDO::CASE_NATURAL,PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION,PDO::ATTR_ORACLE_NULLS => PDO::NULL_NATURAL,PDO::ATTR_STRINGIFY_FETCHES => false,PDO::ATTR_EMULATE_PREPARES => false,
데이터베이스에 설정된 매개변수 매개변수의 연결 구성은 내장된 매개변수와 병합됩니다. 긴 연결을 사용해야 하는 경우 다음과 같이 정의할 수 있는 데이터베이스의 소문자 열 이름을 반환합니다.

'params' => [
  \PDO::ATTR_PERSISTENT => true,  \PDO::ATTR_CASE => \PDO::CASE_LOWER,],

params에서 PDO가 지원하는 모든 연결 매개 변수를 구성할 수 있습니다.

2. 메소드 구성

Db 클래스를 호출할 때 연결 정보를 동적으로 정의할 수 있습니다. 예:

Db::connect([    // 数据库类型
    'type' => 'mysql',    // 数据库连接DSN配置
    'dsn' => '',    // 服务器地址
    'hostname' => '127.0.0.1',    // 数据库名
    'database' => 'thinkphp',    // 数据库用户名
    'username' => 'root',    // 数据库密码
    'password' => '',    // 数据库连接端口
    'hostport' => '',    // 数据库连接参数
    'params' => [],    // 数据库编码默认采用utf8
    'charset' => 'utf8',    // 数据库表前缀
    'prefix' => 'think_',]);
또는 문자열 메소드 사용:

Db::connect('mysql://root:1234@127.0.0.1:3306/thinkphp#utf8');
문자열 연결의 정의 형식은 다음과 같습니다.


 

데이터베이스 유형://사용자 이름:비밀번호@데이터베이스 주소:데이터베이스 포트/데이터베이스 이름#문자 집합

참고: 문자열 모드에서는 접두사 및 연결 매개변수와 같은 일부 매개변수를 정의하지 못할 수도 있습니다.

애플리케이션 구성 파일에 추가 데이터베이스 연결 정보를 구성한 경우(데이터베이스 구성 파일이 아님) 예:

//数据库配置1
'db_config1' => [    
// 数据库类型
    'type' => 'mysql',    
    // 服务器地址
    'hostname' => '127.0.0.1',    
    // 数据库名
    'database' => 'thinkphp',    
    // 数据库用户名
    'username' => 'root',    
    // 数据库密码
    'password' => '', 
    // 数据库编码默认采用utf8
    'charset' => 'utf8',    
    // 数据库表前缀
    'prefix' => 'think_',],
    //数据库配置2
    'db_config2' => 'mysql://root:1234@localhost:3306/thinkphp#utf8';
이를


Db::connect('db_config1');
Db::connect('db_config2');

로 변경할 수 있습니다. 3. 모델 클래스 정의

모델 클래스에 연결 속성이 정의되어 있으면 일반적으로 사용되는 구성 파일에 설정된 기본 연결 정보 대신 모델이 작동 시 지정된 데이터베이스 연결에 자동으로 연결됩니다. some 데이터 테이블은 현재 데이터베이스 연결 외부의 다른 데이터베이스에 있습니다. 예:

//在模型里单独设置数据库连接信息
namespace app\index\model;
use think\Model;class User extends Model
{    protected $connection = [        // 数据库类型
        'type' => 'mysql',        // 数据库连接DSN配置
        'dsn' => '',        // 服务器地址
        'hostname' => '127.0.0.1',        // 数据库名
        'database' => 'thinkphp',        // 数据库用户名
        'username' => 'root',        // 数据库密码
        'password' => '',        // 数据库连接端口
        'hostport' => '',        // 数据库连接参数
        'params' => [],        // 数据库编码默认采用utf8
        'charset' => 'utf8',        // 数据库表前缀
        'prefix' => 'think_',
    ];
}
DSN 문자열을 사용하여 정의할 수도 있습니다. 예:


//在模型里单独设置数据库连接信息
namespace app\index\model; 
use think\Model;class User extends Model
{    
//或者使用字符串定义
    protected $connection = 'mysql://root:1234@127.0.0.1:3306/thinkphp#utf8';
}

ThinkPHP의 데이터베이스 연결은 게으르다는 점에 유의해야 합니다. 인스턴스화 시에는 데이터베이스가 연결되지만 실제 데이터 작업이 있을 때는 데이터베이스에 연결됩니다.

구성 매개변수 참조

다음은 기본적으로 지원되는 데이터베이스 연결 정보입니다.

mas fields _strict필드가 존재하는지 확인하세요trueresultset_typeDataset return typearrayauto_timestamp자동으로 타임스탬프 필드 작성falsesql _explain SQL 성능 분석이 필요한지 디버깅을 켜는 것이 유효합니다falsequery쿼리 개체 지정thinkdbQuerybuilderDatabase Builder 개체 지정Nonepgsql 데이터베이스 드라이버를 사용하는 경우 먼저 thinkphp/library/think/db/connector/pgsql.sql 파일을 데이터베이스로 가져와서 실행하세요.
매개변수 이름 설명 기본값
type 데이터베이스 유형 없음
호스트 이름 데이터베이스 주소 127.0.0.1
데이터베이스 데이터베이스 이름 None
username 데이터베이스 사용자 이름 None
password 데이터베이스 비밀번호 None
hostport 데이터베이스 포트 번호 None
dsn 데이터베이스 연결 dsn 정보 None
params 데이터베이스 연결 매개변수 Empty
charset 데이터베이스 인코딩 utf8
prefix 데이터베이스의 테이블 접두사 None
debug 디버그 모드 여부 false
deploy 데이터베이스 배포 모드: 0 중앙 집중식(단일 서버), 1 분산(마스터-슬레이브 서버) 0
rw_separate 데이터베이스 읽어보세요. 쓰기 분리 마스터 슬레이브 모드는 유효합니다 .False
주의:

위 내용은 데이터베이스에 연결하기 위한 ThinkPHP 데이터베이스 작업의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
이 기사는 cnblogs에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제
ThinkPhp의 내장 테스트 프레임 워크의 주요 기능은 무엇입니까?ThinkPhp의 내장 테스트 프레임 워크의 주요 기능은 무엇입니까?Mar 18, 2025 pm 05:01 PM

이 기사는 ThinkPhp의 내장 테스트 프레임 워크에 대해 논의하여 장치 및 통합 테스트와 같은 주요 기능과 조기 버그 감지 및 개선 된 코드 품질을 통해 응용 프로그램 신뢰성을 향상시키는 방법을 강조합니다.

실시간 주식 시장 데이터 피드 구축에 ThinkPhp를 사용하는 방법은 무엇입니까?실시간 주식 시장 데이터 피드 구축에 ThinkPhp를 사용하는 방법은 무엇입니까?Mar 18, 2025 pm 04:57 PM

기사는 실시간 주식 시장 데이터 피드에 ThinkPHP를 사용하여 설정, 데이터 정확도, 최적화 및 보안 측정에 중점을 둡니다.

서버리스 아키텍처에서 ThinkPhp를 사용하는 데있어 주요 고려 사항은 무엇입니까?서버리스 아키텍처에서 ThinkPhp를 사용하는 데있어 주요 고려 사항은 무엇입니까?Mar 18, 2025 pm 04:54 PM

이 기사는 서버리스 아키텍처에서 ThinkPHP를 사용하기위한 주요 고려 사항에 대해 설명하고 성능 최적화, 무국적 설계 및 보안에 중점을 둡니다. 비용 효율성 및 확장 성과 같은 혜택을 강조하고 도전 과제를 해결합니다.

ThinkPHP 마이크로 서비스에서 서비스 검색 및로드 밸런싱을 구현하는 방법은 무엇입니까?ThinkPHP 마이크로 서비스에서 서비스 검색 및로드 밸런싱을 구현하는 방법은 무엇입니까?Mar 18, 2025 pm 04:51 PM

이 기사에서는 ThinkPHP 마이크로 서비스에서 서비스 검색 및로드 밸런싱 구현, 설정, 모범 사례, 통합 방법 및 권장 도구에 중점을 둡니다. [159 문자]

ThinkPhp의 종속성 주입 컨테이너의 고급 기능은 무엇입니까?ThinkPhp의 종속성 주입 컨테이너의 고급 기능은 무엇입니까?Mar 18, 2025 pm 04:50 PM

ThinkPhp의 IOC 컨테이너는 PHP apps.character 수 : 159의 효율적인 종속성 관리를위한 게으른 하중, 맥락 바인딩 및 메소드 주입과 같은 고급 기능을 제공합니다.

실시간 협업 도구를 구축하는 데 ThinkPhp를 사용하는 방법은 무엇입니까?실시간 협업 도구를 구축하는 데 ThinkPhp를 사용하는 방법은 무엇입니까?Mar 18, 2025 pm 04:49 PM

이 기사는 ThinkPhp를 사용하여 실시간 협업 도구를 구축하고 설정, WebSocket 통합 및 보안 모범 사례에 중점을 둡니다.

SaaS 애플리케이션 구축에 ThinkPhp를 사용하면 어떤 주요 이점이 있습니까?SaaS 애플리케이션 구축에 ThinkPhp를 사용하면 어떤 주요 이점이 있습니까?Mar 18, 2025 pm 04:46 PM

ThinkPhp는 가벼운 디자인, MVC 아키텍처 및 확장 성을 통해 SaaS 앱에 혜택을줍니다. 다양한 기능을 통해 확장 성을 향상시키고 개발 속도를 높이며 보안을 향상시킵니다.

ThinkPHP 및 RabbitMQ로 분산 작업 대기열 시스템을 구축하는 방법은 무엇입니까?ThinkPHP 및 RabbitMQ로 분산 작업 대기열 시스템을 구축하는 방법은 무엇입니까?Mar 18, 2025 pm 04:45 PM

이 기사는 설치, 구성, 작업 관리 및 확장성에 중점을 둔 ThinkPhp 및 RabbitMQ를 사용하여 분산 작업 큐 시스템을 구축합니다. 주요 문제는 고 가용성 보장, 손상과 같은 일반적인 함정을 피하는 것입니다.

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

ZendStudio 13.5.1 맥

ZendStudio 13.5.1 맥

강력한 PHP 통합 개발 환경

Atom Editor Mac 버전 다운로드

Atom Editor Mac 버전 다운로드

가장 인기 있는 오픈 소스 편집기

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

MinGW - Windows용 미니멀리스트 GNU

MinGW - Windows용 미니멀리스트 GNU

이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

맨티스BT

맨티스BT

Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.