다음 튜토리얼 칼럼인 thinkphp에서는 ThinkPHP 데이터베이스 작업을 통해 데이터베이스를 연결하는 방법을 소개하겠습니다. 필요한 친구들에게 도움이 되길 바랍니다!
ThinkPHP에는 다양한 데이터베이스 작업을 캡슐화하는 추상 데이터베이스 액세스 계층이 내장되어 있습니다. 다른 데이터베이스에 대한 다른 코드 및 기본 구현을 작성하지 않고도 작동하려면 공용 Db 클래스만 사용하면 됩니다. 처리할 드라이버. PDO 방법을 사용하면 현재 Mysql, SqlServer, PgSQL, Sqlite 및 기타 데이터베이스에 대한 지원이 포함됩니다.
애플리케이션이 데이터베이스를 사용해야 하는 경우 데이터베이스 연결 정보를 구성해야 합니다. 데이터베이스 구성 파일을 정의하는 방법에는 여러 가지가 있습니다.
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' => '\org\db\Mysql',
return [ // 服务器地址 'hostname' => '192.168.1.100', // 数据库名 'database' => 'admin',];
// 开启断线重连 '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_', ]; }
//在模型里单独设置数据库连接信息 namespace app\index\model; use think\Model;class User extends Model { //或者使用字符串定义 protected $connection = 'mysql://root:1234@127.0.0.1:3306/thinkphp#utf8'; }
ThinkPHP의 데이터베이스 연결은 게으르다는 점에 유의해야 합니다. 인스턴스화 시에는 데이터베이스가 연결되지만 실제 데이터 작업이 있을 때는 데이터베이스에 연결됩니다.
구성 매개변수 참조
다음은 기본적으로 지원되는 데이터베이스 연결 정보입니다.
매개변수 이름 | 설명 | 기본값 |
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 | |
필드가 존재하는지 확인하세요 | true | |
Dataset return type | array | |
자동으로 타임스탬프 필드 작성 | false | |
SQL 성능 분석이 필요한지 디버깅을 켜는 것이 유효합니다 | false | |
쿼리 개체 지정 | thinkdbQuery | |
Database Builder 개체 지정 | None | |
주의: | ||
위 내용은 데이터베이스에 연결하기 위한 ThinkPHP 데이터베이스 작업의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!