快速學(xué)習(xí)PHP數(shù)據(jù)庫文件使用
PHP還是比較常用的,于是我研究了一下PHP數(shù)據(jù)庫文件,在這里拿出來和大家分享一下,希望對(duì)大家有用。我們會(huì)看到一個(gè)應(yīng)用程序中,每個(gè)表都在一個(gè)單獨(dú)的數(shù)據(jù)庫中。在非常大的數(shù)據(jù)庫中這樣做是合理的,但是對(duì)于一般的應(yīng)用程序,則不需要這種級(jí)別的分割。此外,不能跨數(shù)據(jù)庫執(zhí)行關(guān)系查詢,這會(huì)影響使用關(guān)系數(shù)據(jù)庫的整體思想,更不用說跨多個(gè)數(shù)據(jù)庫管理表會(huì)更困難了。 那么,多個(gè)數(shù)據(jù)庫應(yīng)該是什么樣的呢?首先,您需要一些數(shù)據(jù)。清單 1 展示了分成 4 個(gè)文件的這樣的數(shù)據(jù)。
清單 1. PHP數(shù)據(jù)庫文件
- Files.sql:
- CREATE TABLE files (
- id MEDIUMINT,
- user_id MEDIUMINT,
- name TEXT,
- path TEXT
- );
- Load_files.sql:
- INSERT INTO files VALUES ( 1, 1, 'test1.jpg', 'files/test1.jpg' );
- INSERT INTO files VALUES ( 2, 1, 'test2.jpg', 'files/test2.jpg' );
- Users.sql:
- DROP TABLE IF EXISTS users;
- CREATE TABLE users (
- id MEDIUMINT,
- login TEXT,
- password TEXT
- );
- Load_users.sql:
- INSERT INTO users VALUES ( 1, 'jack', 'pass' );
- INSERT INTO users VALUES ( 2, 'jon', 'pass' );
#T#您可以用很多的方式創(chuàng)建數(shù)據(jù)庫設(shè)計(jì)、數(shù)據(jù)庫訪問和基于數(shù)據(jù)庫的 PHP 業(yè)務(wù)邏輯代碼,但最終一般以錯(cuò)誤告終,以及在遇到這些問題時(shí)如何修復(fù)它們。在這些文件的多數(shù)據(jù)庫版本中,您應(yīng)該將 SQL 語句加載到一個(gè)數(shù)據(jù)庫中,然后將 users SQL 語句加載到另一個(gè)數(shù)據(jù)庫中。用于在數(shù)據(jù)庫中查詢與某個(gè)特定用戶相關(guān)聯(lián)的文件的 PHP 代碼如下所示。get_user 函數(shù)連接到包含用戶表的數(shù)據(jù)庫并檢索給定用戶的 ID。get_files 函數(shù)連接到文件表并檢索與給定用戶相關(guān)聯(lián)的文件行。做所有這些事情的一個(gè)更好辦法是將數(shù)據(jù)加載到一個(gè)數(shù)據(jù)庫中,然后執(zhí)行查詢,比如下面的查詢。
清單 2. PHP數(shù)據(jù)庫文件Getfiles.php
- <?php
- require_once("DB.php");
- function get_user( $name )
- {
- $dsn = 'mysql://root:password@localhost/bad_multi1';
- $db =& DB::Connect( $dsn, array() );
- if (PEAR::isError($db)) { die($db->getMessage()); }
- $res = $db->query( "SELECT id FROM users WHERE login=?",array( $name ) );
- $uid = null;
- while( $res->fetchInto( $row ) ) { $uid = $row[0]; }
- return $uid;
- }
- function get_files( $name )
- {
- $uid = get_user( $name );
- $rows = array();
- $dsn = 'mysql://root:password@localhost/bad_multi2';
- $db =& DB::Connect( $dsn, array() );
- if (PEAR::isError($db)) { die($db->getMessage()); }
- $res = $db->query( "SELECT * FROM files WHERE user_id=?",array( $uid ) );
- while( $res->fetchInto( $row ) ) { $rows[] = $row; }
- return $rows;
- }
- $files = get_files( 'jack' );
- var_dump( $files );
- ?>
清單 3. Getfiles_good.php
- <?php
- require_once("DB.php");
- function get_files( $name )
- {
- $rows = array();
- $dsn = 'mysql://root:password@localhost/good_multi';
- $db =& DB::Connect( $dsn, array() );
- if (PEAR::isError($db)) { die($db->getMessage()); }
- $res = $db->query("SELECT files.* FROM users, files WHERE
- users.login=? AND users.id=files.user_id",
- array( $name ) );
- while( $res->fetchInto( $row ) ) { $rows[] = $row; }
- return $rows;
- }
- $files = get_files( 'jack' );
- var_dump( $files );
- ?>
該代碼不僅更短,而且也更容易理解和高效。我們不是執(zhí)行兩個(gè)查詢,而是執(zhí)行一個(gè)查詢。盡管該問題聽起來有些牽強(qiáng),但是在實(shí)踐中我們通??偨Y(jié)出所有的表應(yīng)該在同一個(gè)數(shù)據(jù)庫中,除非有非常迫不得已的理由。