Maison > cadre php > PensezPHP > Le framework thinkPHP5 implémente plusieurs connexions à des bases de données

Le framework thinkPHP5 implémente plusieurs connexions à des bases de données

藏色散人
Libérer: 2021-06-07 09:11:51
avant
2945 Les gens l'ont consulté

La section suivante de la colonne du didacticiel du framework thinkphp vous présentera le framework thinkPHP5 pour implémenter des connexions multi-bases de données et des opérations de requête de connexion de données croisées, j'espère que ce sera le cas. utile aux amis dans le besoin !

Les détails sont les suivants :

1. Connexions à plusieurs bases de données

Méthode 1 : Connectez-vous si nécessaire Pour les autres bases de données, utilisez la méthode Db::connect() pour vous connecter dynamiquement à la base de données. Les paramètres de la méthode sont des tableaux ou des chaînes configurés par la base de données. Par exemple :

Paramètres de chaîne :

Db::connect('mysql://root:1234@127.0.0.1:3306/thinkphp#utf8');
Copier après la connexion
<🎜. >Paramètres du tableau de configuration :

Db::connect([
  // 数据库类型
  &#39;type&#39;    => &#39;mysql&#39;,
  // 数据库连接DSN配置
  &#39;dsn&#39;     => &#39;&#39;,
  // 服务器地址
  &#39;hostname&#39;  => &#39;127.0.0.1&#39;,
  // 数据库名
  &#39;database&#39;  => &#39;thinkphp&#39;,
  // 数据库用户名
  &#39;username&#39;  => &#39;root&#39;,
  // 数据库密码
  &#39;password&#39;  => &#39;&#39;,
  // 数据库连接端口
  &#39;hostport&#39;  => &#39;&#39;,
  // 数据库连接参数
  &#39;params&#39;   => [],
  // 数据库编码默认采用utf8
  &#39;charset&#39;   => &#39;utf8&#39;,
  // 数据库表前缀
  &#39;prefix&#39;   => &#39;think_&#39;,
]);
Copier après la connexion

Pour une utilisation détaillée, veuillez vous référer au manuel de développement complet de thinkphp5 :

https://www.kancloud.cn/manual/thinkphp5/118059

Méthode 2 : dans l'application Ajoutez plusieurs configurations de base de données au fichier de configuration, par exemple :

&#39;database1&#39; => []//数据库配置数组 
&#39;database2&#39; => []//数据库配置数组
Copier après la connexion

Lorsqu'une connexion est requise, utilisez

pour vous connecter à la base de données spécifiée lors de l'exécution. opérations de base de données, écrivez des fonctions directement dans la chaîne après la connexion, par exemple : Db::connect("database1")

$db = Db::connect("database1");
$db->name("table")->select();
Copier après la connexion

2 Requête de connexion entre bases de données

<🎜. >Méthode 1 :

Utilisez la méthode pour exécuter l'instruction sql et utilisez-la dans l'instruction sql. Spécifiez la base de données et la table de la manière , par exemple : Db::query("sql")database.tableConnectez-vous et interrogez le données avec le même identifiant dans la table1 dans la base de données base de données1 et la table2 dans la base de données base de données2

select * from database1.table1 as t1 inner join database2.table2 as t2 where t1,id=t2.id
Copier après la connexion

Méthode 2 :

Utilisez des boucles pour interroger différentes bases de données séparémentInterrogez maintenant les données dans la base de données1 , parcourez l'ensemble de résultats de la requête et interrogez séparément les données qui répondent aux conditions de la base de données2 pour l'épissage

ps : la description n'est pas en place

.

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!

Étiquettes associées:
source:jb51.net
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
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal