Drupal7 は複数のデータベースを接続し、一般的な問題を解決します_PHP チュートリアル
次の問題が発生した場合:
1.Drupal はどのようにして複数のデータベースに接続しますか?
2. Drupal が複数のデータベースに接続した後、プログラムがエラーを報告したことがわかりました。
3. Drupal が複数のデータベースを取得、追加、変更、または削除すると、データがデータベースに正しく書き込まれないか、空のデータが読み取られます。
4. Drupal で特定の関数を呼び出したり、他のデータベースを制御したりしたいだけですが、失敗しますか?
次の概要と問題の解決方法をよくお読みください。
1. Drupal を複数のデータベースに接続するには?
Drupal が複数のデータベースに接続できるようにするには、$db_url を配列に変換する必要があります。
単一データベースに接続するためのデフォルトの URL 形式 (文字列):
$db_url = 'pgsql://ユーザー名:パスワード@ローカルホスト/データベース名';
別のデータベースをクエリする場合は、$db_url を介してデータベース参照キーを、使用する現在アクティブなデータベースに設定するだけです。
コードをコピー
これがDrupalのデータベース操作の基本操作です。
複数のデータベースにリンクするときにエラーが発生する主な原因は次のとおりです。
1. 他のデータベースに接続するときに SQL エラーが発生しました。これは人間のコード エラーです。2. データベースに接続するときに、データ テーブルが他のデータベースに見つかりません。 SQL が正しい場合、エラーが報告されます ;
解決策:最初の状況では、SQL エラー レポートに従って SQL ステートメントを変更してください。問題は解決されます。
2 番目のケースでは、データベース接続が交差していないかどうかを確認してください。これは、当初は別のデータベースのデータ テーブルを呼び出すつもりでしたが、データベース接続が別の場所に変更されたことを意味します。データベース接続のクロスオーバーに関しては、db_set_active 関数の後の SQL ステートメントがアクティブなデータベースにあるかどうかを注意深く確認してください。
1. Drupal では、SQL ステートメントにデータ テーブルのプレフィックスを付ける必要はありません。データベース操作中に、中括弧 {} を使用してテーブルを追加するだけです。
ただし、データベース ユーザーが複数のデータベースに対する権限を持っている場合、$db_url でデータベースへの接続を設定する必要はなく、直接操作できます。現在のデータベース接続。 クロスデータベース操作を実装するために $db_prefix を設定します:
コードをコピーします
コードは次のとおりです:
'users' => 'usertable.z_',
;
上記のコードが機能すると、現在のすべての Drupal ユーザーとその他の情報が usertable を使用するため、複数の Drupal がユーザー情報データベース usertable を共有できます。z_ はデータ テーブルのプレフィックスを表します。
注:
a) .users テーブルは Drupal ユーザーの基本情報を保存するために使用され、すべてのユーザーが共有する UID とその基本フィールドを保存できます。
b) .sessions テーブルは Drupal ユーザー セッションを保存するために使用され、カウントできます。すべてのサイトのオンライン ユーザーの数;
c).role テーブルはすべての Drupal サイトのロールを保存するために使用されます;
上記の $db_prefix を通じて、グローバルに設定できます。どのデータベースをどのテーブルに使用するか、およびそのテーブルのプレフィックス。これは、Drupal の SQL ステートメントで標準の {table} を使用する場合に便利です。
例:
そのため、Drupal で複数のデータベースの取得、追加、変更、削除が発生し、データがデータベースに正しく書き込まれなかったり、空のデータが読み取られたりした場合は、管理するデータベースとデータ テーブルの場所が正しいことを確認してください。
4. Drupal の関数を呼び出すか、他のデータベースを制御します
global $db_url ['db_logs' ] = 'mysqli: //username:password@localhost/databasename';
db_set_active('db_logs')
$codehere
db_set_active('default');
特に重要なのは、$db_url はグローバル変数であり、ローカル関数のグローバルによって参照される必要があります:
コードをコピー
http://www.bkjia.com/PHPjc/736821.html

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

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

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

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

ホットトピック











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

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

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

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

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

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

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

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