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

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

WBOY
WBOYオリジナル
2016-07-13 10:37:04861ブラウズ

次の問題が発生した場合:
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 までご連絡ください。