ホームページ バックエンド開発 PHPチュートリアル Drupal7 は複数のデータベースを接続し、一般的な問題を解決します_PHP チュートリアル

Drupal7 は複数のデータベースを接続し、一般的な問題を解決します_PHP チュートリアル

Jul 13, 2016 am 10:37 AM

次の問題が発生した場合:
1.Drupal はどのようにして複数のデータベースに接続しますか?
2. Drupal が複数のデータベースに接続した後、プログラムがエラーを報告したことがわかりました。
3. Drupal が複数のデータベースを取得、追加、変更、または削除すると、データがデータベースに正しく書き込まれないか、空のデータが読み取られます。
4. Drupal で特定の関数を呼び出したり、他のデータベースを制御したりしたいだけですが、失敗しますか?
次の概要と問題の解決方法をよくお読みください。
1. Drupal を複数のデータベースに接続するには?
Drupal が複数のデータベースに接続できるようにするには、$db_url を配列に変換する必要があります。
単一データベースに接続するためのデフォルトの URL 形式 (文字列):

コードをコピー コードは次のとおりです:
$db_url = 'mysql://username:password@localhost/databasename'; = 'mysqli: //ユーザー名:パスワード@ローカルホスト/データベース名';
$db_url = 'pgsql://ユーザー名:パスワード@ローカルホスト/データベース名';
複数のデータベースの URL 形式 (配列) をサポートします:


コードをコピー コードは次のとおりです:
$db_url['default'] = 'mysql://drupal:drupal@localhost/drupal'; $db_url ['mydb'] = 'mysql://user:pwd@localhost/anotherdb';
$db_url['db3'] = 'mysql://user:pwd@localhost/yetanotherdb';
別のデータベースをクエリする場合は、$db_url を介してデータベース参照キーを、使用する現在アクティブなデータベースに設定するだけです。

コードをコピー

コードは次のとおりです:db_set_active('mydb'); db_query('SELECT * FROM table_in_anotherdb');デフォルトのデータベース接続に戻ります。
db_set_active('デフォルト')
?>


これがDrupalのデータベース操作の基本操作です。

2. Drupal が複数のデータベースに接続した後、プログラムがエラーを報告したことがわかりました。何が起こったのでしょうか?

複数のデータベースにリンクするときにエラーが発生する主な原因は次のとおりです。

1. 他のデータベースに接続するときに SQL エラーが発生しました。これは人間のコード エラーです。2. データベースに接続するときに、データ テーブルが他のデータベースに見つかりません。 SQL が正しい場合、エラーが報告されます ;

解決策:

最初の状況では、SQL エラー レポートに従って SQL ステートメントを変更してください。問題は解決されます。

2 番目のケースでは、データベース接続が交差していないかどうかを確認してください。これは、当初は別のデータベースのデータ テーブルを呼び出すつもりでしたが、データベース接続が別の場所に変更されたことを意味します。データベース接続のクロスオーバーに関しては、db_set_active 関数の後の SQL ステートメントがアクティブなデータベースにあるかどうかを注意深く確認してください。


3. 複数のデータベースを取得、追加、変更、削除すると Drupal が正しく動作しませんか?



1. Drupal では、SQL ステートメントにデータ テーブルのプレフィックスを付ける必要はありません。データベース操作中に、中括弧 {} を使用してテーブルを追加するだけです。

例: db_query('SELECT * FROM {table_in_anotherdb}');

ただし、データベース ユーザーが複数のデータベースに対する権限を持っている場合、$db_url でデータベースへの接続を設定する必要はなく、直接操作できます。現在のデータベース接続。 クロスデータベース操作を実装するために $db_prefix を設定します:


コードをコピーします

コードは次のとおりです:

$db_prefix = array( 'default' => ”, 'authmap' => 'z_'、 'profile_fields' => 'usertable.z_'、
'profile_values' => 'users_roles' => 'users_fields' => 'usertable.',
'role' => 'usertable.z_',
'users' => 'usertable.z_',
;

上記のコードが機能すると、現在のすべての Drupal ユーザーとその他の情報が usertable を使用するため、複数の Drupal がユーザー情報データベース usertable を共有できます。z_ はデータ テーブルのプレフィックスを表します。

注:

a) .users テーブルは Drupal ユーザーの基本情報を保存するために使用され、すべてのユーザーが共有する UID とその基本フィールドを保存できます。
b) .sessions テーブルは Drupal ユーザー セッションを保存するために使用され、カウントできます。すべてのサイトのオンライン ユーザーの数;
c).role テーブルはすべての Drupal サイトのロールを保存するために使用されます;
上記の $db_prefix を通じて、グローバルに設定できます。どのデータベースをどのテーブルに使用するか、およびそのテーブルのプレフィックス。これは、Drupal の SQL ステートメントで標準の {table} を使用する場合に便利です。

2. $db_prefix を介して設定しない場合、最も簡単な方法は、SQL ステートメントにデータベース テーブル名を直接記述することです。

例:


コードをコピーします コードは次のとおりです:
db_query("SELECT uid FROM test.z_table1 WHERE name = '%s' and pass = '%s'", $name, md5($pass) );

上記の SQL ステートメントは、テスト データベースと z_table データ テーブルを直接見つけます。

そのため、Drupal で複数のデータベースの取得、追加、変更、削除が発生し、データがデータベースに正しく書き込まれなかったり、空のデータが読み取られたりした場合は、管理するデータベースとデータ テーブルの場所が正しいことを確認してください。


4. Drupal の関数を呼び出すか、他のデータベースを制御します

以下の関数フレームワークのコードを見てください:


コードをコピーします コードは次のとおりです:
function test_fuc() {
global $db_url ['db_logs' ] = 'mysqli: //username:password@localhost/databasename';
db_set_active('db_logs')
$codehere
db_set_active('default');


特に重要なのは、$db_url はグローバル変数であり、ローカル関数のグローバルによって参照される必要があります:


コードをコピー
コードは次のとおりです: global $db_url; // グローバル変数を取得します
;データベースをセットアップした後は、必ず db_set_active('default'); を使用し、データベース接続をデフォルトに復元するように設定してください。


http://www.bkjia.com/PHPjc/736821.html

www.bkjia.comtru​​ehttp://www.bkjia.com/PHPjc/736821.html技術記事次の問題が発生した場合: 1.Drupal はどのようにして複数のデータベースに接続しますか? 2. Drupal が複数のデータベースに接続した後、プログラムがエラーを報告したことがわかりました。何が起こったのでしょうか? 3.Drupal が取得、追加、...
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

Laravelでフラッシュセッションデータを使用します Laravelでフラッシュセッションデータを使用します Mar 12, 2025 pm 05:08 PM

Laravelは、直感的なフラッシュメソッドを使用して、一時的なセッションデータの処理を簡素化します。これは、アプリケーション内に簡単なメッセージ、アラート、または通知を表示するのに最適です。 データは、デフォルトで次の要求のためにのみ持続します。 $リクエスト -

LaravelのバックエンドでReactアプリを構築する:パート2、React LaravelのバックエンドでReactアプリを構築する:パート2、React Mar 04, 2025 am 09:33 AM

これは、LaravelバックエンドとのReactアプリケーションの構築に関するシリーズの2番目と最終部分です。シリーズの最初の部分では、基本的な製品上場アプリケーションのためにLaravelを使用してRESTFUL APIを作成しました。このチュートリアルでは、開発者になります

PHPのカール:REST APIでPHPカール拡張機能を使用する方法 PHPのカール:REST APIでPHPカール拡張機能を使用する方法 Mar 14, 2025 am 11:42 AM

PHPクライアントURL(CURL)拡張機能は、開発者にとって強力なツールであり、リモートサーバーやREST APIとのシームレスな対話を可能にします。尊敬されるマルチプロトコルファイル転送ライブラリであるLibcurlを活用することにより、PHP Curlは効率的なexecuを促進します

Laravelテストでの簡略化されたHTTP応答のモッキング Laravelテストでの簡略化されたHTTP応答のモッキング Mar 12, 2025 pm 05:09 PM

Laravelは簡潔なHTTP応答シミュレーション構文を提供し、HTTP相互作用テストを簡素化します。このアプローチは、テストシミュレーションをより直感的にしながら、コード冗長性を大幅に削減します。 基本的な実装は、さまざまな応答タイプのショートカットを提供します。 Illuminate \ support \ facades \ httpを使用します。 http :: fake([[ 'google.com' => 'hello world'、 'github.com' => ['foo' => 'bar']、 'forge.laravel.com' =>

Codecanyonで12の最高のPHPチャットスクリプト Codecanyonで12の最高のPHPチャットスクリプト Mar 13, 2025 pm 12:08 PM

顧客の最も差し迫った問題にリアルタイムでインスタントソリューションを提供したいですか? ライブチャットを使用すると、顧客とのリアルタイムな会話を行い、すぐに問題を解決できます。それはあなたがあなたのカスタムにより速いサービスを提供することを可能にします

Laravelの通知 Laravelの通知 Mar 04, 2025 am 09:22 AM

この記事では、Laravel Webフレームワークの通知システムを検討します。 Laravelの通知システムを使用すると、さまざまなチャネルでユーザーに通知を送信できます。今日は、通知ovを送信する方法について説明します

PHPにおける後期静的結合の概念を説明します。 PHPにおける後期静的結合の概念を説明します。 Mar 21, 2025 pm 01:33 PM

記事では、PHP 5.3で導入されたPHPの後期静的結合(LSB)について説明し、より柔軟な継承を求める静的メソッドコールのランタイム解像度を可能にします。 LSBの実用的なアプリケーションと潜在的なパフォーマ

PHPロギング:PHPログ分析のベストプラクティス PHPロギング:PHPログ分析のベストプラクティス Mar 10, 2025 pm 02:32 PM

PHPロギングは、Webアプリケーションの監視とデバッグ、および重要なイベント、エラー、ランタイムの動作をキャプチャするために不可欠です。システムのパフォーマンスに関する貴重な洞察を提供し、問題の特定に役立ち、より速いトラブルシューティングをサポートします

See all articles