欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

PHP 數(shù)據(jù)庫(kù) 常見問題小結(jié)第2/3頁(yè)

 更新時(shí)間:2009年06月22日 00:40:48   作者:  
揭露 PHP 應(yīng)用程序中出現(xiàn)的五個(gè)常見數(shù)據(jù)庫(kù)問題 —— 包括數(shù)據(jù)庫(kù)模式設(shè)計(jì)、數(shù)據(jù)庫(kù)訪問和使用數(shù)據(jù)庫(kù)的業(yè)務(wù)邏輯代碼 —— 以及它們的解決方案。

現(xiàn)在我不是獲得最大的 id 值,而是直接使用 INSERT 語(yǔ)句來(lái)插入數(shù)據(jù),然后使用 SELECT 語(yǔ)句來(lái)檢索最后插入的記錄的 id。該代碼比最初的版本及其相關(guān)模式要簡(jiǎn)單得多,且效率更高。

問題 3:使用多個(gè)數(shù)據(jù)庫(kù)

偶爾,我們會(huì)看到一個(gè)應(yīng)用程序中,每個(gè)表都在一個(gè)單獨(dú)的數(shù)據(jù)庫(kù)中。在非常大的數(shù)據(jù)庫(kù)中這樣做是合理的,但是對(duì)于一般的應(yīng)用程序,則不需要這種級(jí)別的分割。此外,不能跨數(shù)據(jù)庫(kù)執(zhí)行關(guān)系查詢,這會(huì)影響使用關(guān)系數(shù)據(jù)庫(kù)的整體思想,更不用說(shuō)跨多個(gè)數(shù)據(jù)庫(kù)管理表會(huì)更困難了。

那么,多個(gè)數(shù)據(jù)庫(kù)應(yīng)該是什么樣的呢?首先,您需要一些數(shù)據(jù)。清單 7 展示了分成 4 個(gè)文件的這樣的數(shù)據(jù)。


Files.sql:
復(fù)制代碼 代碼如下:

CREATE TABLE files (
id MEDIUMINT,
user_id MEDIUMINT,
name TEXT,
path TEXT
);

Load_files.sql:
復(fù)制代碼 代碼如下:

INSERT INTO files VALUES ( 1, 1, 'test1.jpg', 'files/test1.jpg' );
INSERT INTO files VALUES ( 2, 1, 'test2.jpg', 'files/test2.jpg' );

Users.sql:
復(fù)制代碼 代碼如下:

DROP TABLE IF EXISTS users;
CREATE TABLE users (
id MEDIUMINT,
login TEXT,
password TEXT
);

Load_users.sql:
復(fù)制代碼 代碼如下:

INSERT INTO users VALUES ( 1, 'jack', 'pass' );
INSERT INTO users VALUES ( 2, 'jon', 'pass' );


清單 7. 數(shù)據(jù)庫(kù)文件
在這些文件的多數(shù)據(jù)庫(kù)版本中,您應(yīng)該將 SQL 語(yǔ)句加載到一個(gè)數(shù)據(jù)庫(kù)中,然后將 users SQL 語(yǔ)句加載到另一個(gè)數(shù)據(jù)庫(kù)中。用于在數(shù)據(jù)庫(kù)中查詢與某個(gè)特定用戶相關(guān)聯(lián)的文件的 PHP 代碼如下所示。


復(fù)制代碼 代碼如下:

<?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 函數(shù)連接到包含用戶表的數(shù)據(jù)庫(kù)并檢索給定用戶的 ID。get_files 函數(shù)連接到文件表并檢索與給定用戶相關(guān)聯(lián)的文件行。

做所有這些事情的一個(gè)更好辦法是將數(shù)據(jù)加載到一個(gè)數(shù)據(jù)庫(kù)中,然后執(zhí)行查詢,比如下面的查詢。


復(fù)制代碼 代碼如下:

<?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

相關(guān)文章

  • php保留數(shù)字小數(shù)點(diǎn)后兩位的方法

    php保留數(shù)字小數(shù)點(diǎn)后兩位的方法

    我們?cè)趯W(xué)習(xí)或生活中經(jīng)常會(huì)遇到需要保留數(shù)字小數(shù)點(diǎn)后兩位的問題,所以本文小編給大家介紹了使用php保留數(shù)字小數(shù)點(diǎn)后兩位的方法,文中通過(guò)代碼示例介紹的非常詳細(xì),感興趣的同學(xué)可以參考閱讀下
    2023-12-12
  • PHP面向?qū)ο蟪绦蛟O(shè)計(jì)之類常量用法實(shí)例

    PHP面向?qū)ο蟪绦蛟O(shè)計(jì)之類常量用法實(shí)例

    這篇文章主要介紹了PHP面向?qū)ο蟪绦蛟O(shè)計(jì)之類常量用法,是PHP面向?qū)ο蟪绦蛟O(shè)計(jì)中非常重要的一個(gè)概念,對(duì)于PHP初學(xué)者來(lái)說(shuō)更是有必要加以牢固掌握,需要的朋友可以參考下
    2014-08-08
  • php !function_exists("T7FC56270E7A70FA81A5935B72EACBE29"))代碼解密

    php !function_exists("T7FC56270E7A70FA81A5935B72EACBE29

    今天在百度知道上面有個(gè)朋友問php代碼解密的問題,看了代碼不是常見幾種比較感興趣,特意搜索了下,發(fā)現(xiàn)下面的方法,解決了,具體的看最后的說(shuō)明。
    2011-01-01
  • php遇到錯(cuò)誤Call to undefined function ImageCreate()解決方法

    php遇到錯(cuò)誤Call to undefined function ImageCreate()解決方法

    剛配置好服務(wù)器,運(yùn)行php的時(shí)候提示Call to undefined function imagecreate錯(cuò)誤,經(jīng)過(guò)百度發(fā)現(xiàn)是php不支持gd庫(kù),linux服務(wù)器需要重新make,windows下比較簡(jiǎn)單了,下面是具體的方法
    2021-09-09
  • PHP正則刪除HTML代碼中寬高樣式的方法

    PHP正則刪除HTML代碼中寬高樣式的方法

    這篇文章主要介紹了PHP正則刪除HTML代碼中寬高樣式的方法,涉及php針對(duì)HTML代碼的正則匹配、替換等操作技巧,需要的朋友可以參考下
    2017-06-06
  • php mysql數(shù)據(jù)庫(kù)操作分頁(yè)類

    php mysql數(shù)據(jù)庫(kù)操作分頁(yè)類

    如果您加了新功能,或者是有改進(jìn),請(qǐng)與大家一起分享。
    2008-06-06
  • 一個(gè)數(shù)據(jù)采集類

    一個(gè)數(shù)據(jù)采集類

    一個(gè)數(shù)據(jù)采集類...
    2007-02-02
  • php 將字符串按大寫字母分隔成字符串?dāng)?shù)組

    php 將字符串按大寫字母分隔成字符串?dāng)?shù)組

    php 將字符串按大寫字母分隔成字符串?dāng)?shù)組,需要的朋友可以參考下。
    2010-04-04
  • ThinkPHP路由詳解

    ThinkPHP路由詳解

    ThinkPHP路由通俗的說(shuō),他是一個(gè)url的傳輸規(guī)則,例如:index.php?g=Home&m=Index&a=price 這個(gè)規(guī)則也是可以變化的,& 可以設(shè)置為@或者其他,規(guī)則主要有pathinfo等,在設(shè)置偽靜態(tài)的時(shí)候也用的著他
    2015-07-07
  • PHP實(shí)現(xiàn)防盜鏈的方法分析

    PHP實(shí)現(xiàn)防盜鏈的方法分析

    這篇文章主要介紹了PHP實(shí)現(xiàn)防盜鏈的方法,結(jié)合實(shí)例形式分析了php防盜鏈所涉及的相關(guān)技術(shù)與具體實(shí)現(xiàn)技巧,需要的朋友可以參考下
    2017-07-07

最新評(píng)論