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

데이터베이스에 연결하기 위한 ThinkPHP 데이터베이스 작업

藏色散人
藏色散人앞으로
2021-01-22 14:29:153965검색

다음 튜토리얼 칼럼인 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.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제