Maison cadre php PensezPHP Opération de base de données ThinkPHP pour se connecter à la base de données

Opération de base de données ThinkPHP pour se connecter à la base de données

Jan 22, 2021 pm 02:29 PM
thinkphp

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
  • 2. Configuration de la méthode
  • 3. Définition de la classe de modèle
  • Référence des paramètres de configuration

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,];
Copier après la connexion
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',
Copier après la connexion

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',];
Copier après la connexion

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,
Copier après la connexion

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,
Copier après la connexion
).

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,],
Copier après la connexion

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_',]);
Copier après la connexion

Ou utilisez la méthode de chaîne :

Db::connect('mysql://root:1234@127.0.0.1:3306/thinkphp#utf8');
Copier après la connexion

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.


Si nous avons configuré des informations de connexion à la base de données supplémentaires dans le

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';
Copier après la connexion
Nous pouvons le changer en

Db::connect('db_config1');
Db::connect('db_config2');
Copier après la connexion

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_',
    ];
}
Copier après la connexion

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';
}
Copier après la connexion

Il convient de noter que la connexion à la base de données de ThinkPHP est paresseuse. , ce n'est donc pas le cas. La base de données est connectée lors de l'instanciation, mais sera connectée à la base de données lors d'une opération réelle sur les données.

Référence des paramètres de configuration

Voici les informations de connexion à la base de données prises en charge par défaut :

参数名 描述 默认值
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对象

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.

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!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Comment exécuter le projet thinkphp Comment exécuter le projet thinkphp Apr 09, 2024 pm 05:33 PM

Pour exécuter le projet ThinkPHP, vous devez : installer Composer ; utiliser Composer pour créer le projet ; entrer dans le répertoire du projet et exécuter php bin/console serve ; visiter http://localhost:8000 pour afficher la page d'accueil.

Il existe plusieurs versions de thinkphp Il existe plusieurs versions de thinkphp Apr 09, 2024 pm 06:09 PM

ThinkPHP dispose de plusieurs versions conçues pour différentes versions de PHP. Les versions majeures incluent 3.2, 5.0, 5.1 et 6.0, tandis que les versions mineures sont utilisées pour corriger les bogues et fournir de nouvelles fonctionnalités. La dernière version stable est ThinkPHP 6.0.16. Lorsque vous choisissez une version, tenez compte de la version PHP, des exigences en matière de fonctionnalités et du support de la communauté. Il est recommandé d'utiliser la dernière version stable pour de meilleures performances et une meilleure assistance.

Comment exécuter thinkphp Comment exécuter thinkphp Apr 09, 2024 pm 05:39 PM

Étapes pour exécuter ThinkPHP Framework localement : Téléchargez et décompressez ThinkPHP Framework dans un répertoire local. Créez un hôte virtuel (facultatif) pointant vers le répertoire racine ThinkPHP. Configurez les paramètres de connexion à la base de données. Démarrez le serveur Web. Initialisez l'application ThinkPHP. Accédez à l'URL de l'application ThinkPHP et exécutez-la.

Suggestions de développement : Comment utiliser le framework ThinkPHP pour implémenter des tâches asynchrones Suggestions de développement : Comment utiliser le framework ThinkPHP pour implémenter des tâches asynchrones Nov 22, 2023 pm 12:01 PM

"Suggestions de développement : comment utiliser le framework ThinkPHP pour implémenter des tâches asynchrones" Avec le développement rapide de la technologie Internet, les applications Web ont des exigences de plus en plus élevées pour gérer un grand nombre de requêtes simultanées et une logique métier complexe. Afin d'améliorer les performances du système et l'expérience utilisateur, les développeurs envisagent souvent d'utiliser des tâches asynchrones pour effectuer certaines opérations chronophages, telles que l'envoi d'e-mails, le traitement des téléchargements de fichiers, la génération de rapports, etc. Dans le domaine de PHP, le framework ThinkPHP, en tant que framework de développement populaire, offre des moyens pratiques d'implémenter des tâches asynchrones.

Lequel est le meilleur, Laravel ou thinkphp ? Lequel est le meilleur, Laravel ou thinkphp ? Apr 09, 2024 pm 03:18 PM

Comparaison des performances des frameworks Laravel et ThinkPHP : ThinkPHP fonctionne généralement mieux que Laravel, en se concentrant sur l'optimisation et la mise en cache. Laravel fonctionne bien, mais pour les applications complexes, ThinkPHP peut être mieux adapté.

Comment installer thinkphp Comment installer thinkphp Apr 09, 2024 pm 05:42 PM

Étapes d'installation de ThinkPHP : Préparez les environnements PHP, Composer et MySQL. Créez des projets à l'aide de Composer. Installez le framework ThinkPHP et ses dépendances. Configurez la connexion à la base de données. Générez le code de l'application. Lancez l'application et visitez http://localhost:8000.

Quelles sont les performances de thinkphp ? Quelles sont les performances de thinkphp ? Apr 09, 2024 pm 05:24 PM

ThinkPHP est un framework PHP hautes performances présentant des avantages tels que le mécanisme de mise en cache, l'optimisation du code, le traitement parallèle et l'optimisation des bases de données. Les tests de performances officiels montrent qu'il peut gérer plus de 10 000 requêtes par seconde et qu'il est largement utilisé dans les sites Web à grande échelle et les systèmes d'entreprise tels que JD.com et Ctrip dans les applications réelles.

Suggestions de développement : Comment utiliser le framework ThinkPHP pour le développement d'API Suggestions de développement : Comment utiliser le framework ThinkPHP pour le développement d'API Nov 22, 2023 pm 05:18 PM

Suggestions de développement : Comment utiliser le framework ThinkPHP pour le développement d'API Avec le développement continu d'Internet, l'importance de l'API (Application Programming Interface) est devenue de plus en plus importante. L'API est un pont de communication entre différentes applications. Elle peut réaliser le partage de données, l'appel de fonctions et d'autres opérations, et offre aux développeurs une méthode de développement relativement simple et rapide. En tant qu'excellent framework de développement PHP, le framework ThinkPHP est efficace, évolutif et facile à utiliser.

See all articles