PHP 數據庫 常見問題小結第2/3頁
更新時間:2009年06月22日 00:40:48 作者:
揭露 PHP 應用程序中出現的五個常見數據庫問題 —— 包括數據庫模式設計、數據庫訪問和使用數據庫的業(yè)務邏輯代碼 —— 以及它們的解決方案。
現在我不是獲得最大的 id 值,而是直接使用 INSERT 語句來插入數據,然后使用 SELECT 語句來檢索最后插入的記錄的 id。該代碼比最初的版本及其相關模式要簡單得多,且效率更高。
問題 3:使用多個數據庫
偶爾,我們會看到一個應用程序中,每個表都在一個單獨的數據庫中。在非常大的數據庫中這樣做是合理的,但是對于一般的應用程序,則不需要這種級別的分割。此外,不能跨數據庫執(zhí)行關系查詢,這會影響使用關系數據庫的整體思想,更不用說跨多個數據庫管理表會更困難了。
那么,多個數據庫應該是什么樣的呢?首先,您需要一些數據。清單 7 展示了分成 4 個文件的這樣的數據。
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' );
清單 7. 數據庫文件
在這些文件的多數據庫版本中,您應該將 SQL 語句加載到一個數據庫中,然后將 users SQL 語句加載到另一個數據庫中。用于在數據庫中查詢與某個特定用戶相關聯的文件的 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 );
?>
清單 8. Getfiles.php
get_user 函數連接到包含用戶表的數據庫并檢索給定用戶的 ID。get_files 函數連接到文件表并檢索與給定用戶相關聯的文件行。
做所有這些事情的一個更好辦法是將數據加載到一個數據庫中,然后執(zhí)行查詢,比如下面的查詢。
復制代碼 代碼如下:
<?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 );
?>
清單 9. Getfiles_good.php
相關文章
PHP中auto_prepend_file與auto_append_file用法實例分析
這篇文章主要介紹了PHP中auto_prepend_file與auto_append_file用法,較為詳細的講述了配置信息的休息以及函數的用法和注意事項,需要的朋友可以參考下2014-09-09
使用git遷移Laravel項目至新開發(fā)環(huán)境的步驟詳解
這篇文章主要介紹了遷移Laravel項目至新開發(fā)環(huán)境的步驟詳解,需要的朋友可以參考下2020-04-04
php數組函數序列之array_combine() - 數組合并函數使用說明
array_combine() 函數通過合并兩個數組來創(chuàng)建一個新數組,其中的一個數組是鍵名,另一個數組的值為鍵值2011-10-10
php 自定義函數實現將數據 以excel 表格形式導出示例
這篇文章主要介紹了php 自定義函數實現將數據 以excel 表格形式導出,結合實例形式分析了PHP操作二維數組的遍歷與Excel格式輸出相關實現技巧,需要的朋友可以參考下2019-11-11

