La colonne tutorielle suivante de thinkphp vous présentera comment connecter la base de données dans le fonctionnement de la base de données ThinkPHP. J'espère qu'elle sera utile à ceux qui en ont besoin !
ThinkPHP dispose d'une couche d'accès à la base de données abstraite intégrée qui encapsule différentes opérations de base de données. Nous avons uniquement besoin d'utiliser la classe Db publique pour fonctionner sans écrire différents codes et implémentations sous-jacentes pour différentes bases de données. appellera automatiquement le pilote de base de données correspondant pour le traitement. Utilisant la méthode PDO, il inclut actuellement la prise en charge de Mysql, SqlServer, PgSQL, Sqlite et d'autres bases de données.
Si l'application doit utiliser une base de données, les informations de connexion à la base de données doivent être configurées. Il existe de nombreuses façons de définir le fichier de configuration de la base de données.
1. Définition du fichier de configuration
La méthode de configuration courante consiste à ajouter les paramètres de configuration suivants dans database.php sous le répertoire de l'application ou le répertoire du module :
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 prend en charge une définition complète de l'espace de noms. S'il n'y a pas de définition d'espace de noms, thinkdbconnector est utilisé comme espace de noms par défaut. Si vous utilisez le propre pilote de base de données étendue de l'application, il peut être configuré comme : <.>
// 数据库类型 'type' => '\org\db\Mysql',
représente la base de données. Le connecteur utilise la classe orgdbMysql comme pilote de connexion à la base de données au lieu du thinkdbconnectorMysql par défaut.
Chaque module peut définir des paramètres de connexion à la base de données indépendants, et les mêmes paramètres de configuration n'ont pas besoin d'être définis à plusieurs reprises. Par exemple, nous pouvons le définir dans le fichier de configuration database.php du module admin :
return [ // 服务器地址 'hostname' => '192.168.1.100', // 数据库名 'database' => 'admin',];
Indique que l'adresse de la base de données du module d'administration est modifiée en 192.168.1.100, le nom de la base de données est modifié en admin et les autres paramètres de connexion sont les mêmes que la configuration dans la base de données.php de l'application.
À partir de la V5.0.6+, le mécanisme de déconnexion et de reconnexion de Mysql est pris en charge. Il est désactivé par défaut. Si nécessaire, ajoutez :
// 开启断线重连 'break_reconnect' => true,
Connexion. paramètresVous pouvez ajouter des paramètres de connexion à la base de données pour différents besoins de connexion (pour des paramètres de connexion spécifiques, veuillez vous référer au manuel PHP. Les paramètres intégrés incluent les éléments suivants :
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,).
La configuration de la connexion dans le paramètre params défini dans la base de données sera fusionnée avec les paramètres de configuration intégrés. Si vous devez utiliser une connexion longue et renvoyer le nom de la colonne en minuscules de la base de données, vous pouvez le définir dans ce qui suit. manière :
'params' => [ \PDO::ATTR_PERSISTENT => true, \PDO::ATTR_CASE => \PDO::CASE_LOWER,],Vous pouvez configurer tous les paramètres de connexion pris en charge par PDO dans params.
2. Configuration de la méthode On peut définir dynamiquement les informations de connexion lors de l'appel de la classe Db, par exemple :
Db::connect([ // 数据库类型 'type' => 'mysql', // 数据库连接DSN配置 'dsn' => '', // 服务器地址 'hostname' => '127.0.0.1', // 数据库名 'database' => 'thinkphp', // 数据库用户名 'username' => 'root', // 数据库密码 'password' => '', // 数据库连接端口 'hostport' => '', // 数据库连接参数 'params' => [], // 数据库编码默认采用utf8 'charset' => 'utf8', // 数据库表前缀 'prefix' => 'think_',]);
Ou utilisez la méthode de chaîne :
Db::connect('mysql://root:1234@127.0.0.1:3306/thinkphp#utf8');
Le format de définition de la connexion par chaîne est :
Type de base de données://nom d'utilisateur:mot de passe@adresse de la base de données : Port de la base de données/nom de la base de données #Jeu de caractères
Remarque : le mode chaîne peut ne pas être en mesure de définir certains paramètres, tels que le préfixe et les paramètres de connexion.fichier de configuration de l'application (notez qu'il ne s'agit pas d'un fichier de configuration de base de données), par exemple : //数据库配置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';
Nous pouvons le changer en
Db::connect('db_config1'); Db::connect('db_config2');
3. Définition de la classe modèleSi dans un certaine classe de modèle Si l'attribut de connexion y est défini, le modèle se connectera automatiquement à la connexion à la base de données donnée lors du fonctionnement, au lieu des informations de connexion par défaut définies dans le fichier de configuration. Il est généralement utilisé pour certaines tables de données situées dans d'autres bases de données extérieures. la connexion actuelle à la base de données. Par exemple :
//在模型里单独设置数据库连接信息 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_', ]; }
peut également être défini en mode chaîne DSN, par exemple :
//在模型里单独设置数据库连接信息 namespace app\index\model; use think\Model;class User extends Model { //或者使用字符串定义 protected $connection = 'mysql://root:1234@127.0.0.1:3306/thinkphp#utf8'; }
Référence des paramètres de configuration
Voici les informations de connexion à la base de données prises en charge par défaut :Remarque : Si vous utilisez le pilote de base de données pgsql, veuillez d'abord importer le fichier thinkphp/library/think/db/connector/pgsql.sql dans la base de données pour exécution.
参数名
描述
默认值
type
数据库类型
无
hostname
数据库地址
127.0.0.1
database
数据库名称
无
username
数据库用户名
无
password
数据库密码
无
hostport
数据库端口号
无
dsn
数据库连接dsn信息
无
params
数据库连接参数
空
charset
数据库编码
utf8
prefix
数据库的表前缀
无
debug
是否调试模式
false
deploy
数据库部署方式:0 集中式(单一服务器),1 分布式(主从服务器)
0
rw_separate
数据库读写是否分离 主从式有效
false
master_num
读写分离后 主服务器数量
1
slave_no
指定从服务器序号
无
fields_strict
是否严格检查字段是否存在
true
resultset_type
数据集返回类型
array
auto_timestamp
自动写入时间戳字段
false
sql_explain
是否需要进行SQL性能分析 开启调试有效
false
query
指定查询对象
thinkdbQuery
builder
指定数据库Builder对象
无
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!