av激情亚洲男人的天堂国语,日韩欧美精品一中文字幕,无码av一区二区三区无码,国产又色又爽又刺激的a片,国产又色又爽又刺激的a片

快速學(xué)習(xí)PHP數(shù)據(jù)庫(kù)文件使用

PHP還是比較常用的,于是我研究了一下PHP數(shù)據(jù)庫(kù)文件,在這里拿出來(lái)和大家分享一下,希望對(duì)大家有用。我們會(huì)看到一個(gè)應(yīng)用程序中,每個(gè)表都在一個(gè)單獨(dú)的數(shù)據(jù)庫(kù)中。在非常大的數(shù)據(jù)庫(kù)中這樣做是合理的,但是對(duì)于一般的應(yīng)用程序,則不需要這種級(jí)別的分割。此外,不能跨數(shù)據(jù)庫(kù)執(zhí)行關(guān)系查詢(xún),這會(huì)影響使用關(guān)系數(shù)據(jù)庫(kù)的整體思想,更不用說(shuō)跨多個(gè)數(shù)據(jù)庫(kù)管理表會(huì)更困難了。 那么,多個(gè)數(shù)據(jù)庫(kù)應(yīng)該是什么樣的呢?首先,您需要一些數(shù)據(jù)。清單 1 展示了分成 4 個(gè)文件的這樣的數(shù)據(jù)。

成都創(chuàng)新互聯(lián)公司-專(zhuān)業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性?xún)r(jià)比江永網(wǎng)站開(kāi)發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫(kù),直接使用。一站式江永網(wǎng)站制作公司更省心,省錢(qián),快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋江永地區(qū)。費(fèi)用合理售后完善,十余年實(shí)體公司更值得信賴(lài)。

清單 1. PHP數(shù)據(jù)庫(kù)文件

 
 
  1. Files.sql:
  2. CREATE TABLE files (
  3. id MEDIUMINT,
  4. user_id MEDIUMINT,
  5. name TEXT,
  6. path TEXT
  7. );
  8. Load_files.sql:
  9. INSERT INTO files VALUES ( 1, 1, 'test1.jpg', 'files/test1.jpg' );
  10. INSERT INTO files VALUES ( 2, 1, 'test2.jpg', 'files/test2.jpg' );
  11. Users.sql:
  12. DROP TABLE IF EXISTS users;
  13. CREATE TABLE users (
  14. id MEDIUMINT,
  15. login TEXT,
  16. password TEXT
  17. );
  18. Load_users.sql:
  19. INSERT INTO users VALUES ( 1, 'jack', 'pass' );
  20. INSERT INTO users VALUES ( 2, 'jon', 'pass' );

#T#您可以用很多的方式創(chuàng)建數(shù)據(jù)庫(kù)設(shè)計(jì)、數(shù)據(jù)庫(kù)訪問(wèn)和基于數(shù)據(jù)庫(kù)的 PHP 業(yè)務(wù)邏輯代碼,但最終一般以錯(cuò)誤告終,以及在遇到這些問(wèn)題時(shí)如何修復(fù)它們。在這些文件的多數(shù)據(jù)庫(kù)版本中,您應(yīng)該將 SQL 語(yǔ)句加載到一個(gè)數(shù)據(jù)庫(kù)中,然后將 users SQL 語(yǔ)句加載到另一個(gè)數(shù)據(jù)庫(kù)中。用于在數(shù)據(jù)庫(kù)中查詢(xún)與某個(gè)特定用戶(hù)相關(guān)聯(lián)的文件的 PHP 代碼如下所示。get_user 函數(shù)連接到包含用戶(hù)表的數(shù)據(jù)庫(kù)并檢索給定用戶(hù)的 ID。get_files 函數(shù)連接到文件表并檢索與給定用戶(hù)相關(guān)聯(lián)的文件行。做所有這些事情的一個(gè)更好辦法是將數(shù)據(jù)加載到一個(gè)數(shù)據(jù)庫(kù)中,然后執(zhí)行查詢(xún),比如下面的查詢(xún)。

清單 2. PHP數(shù)據(jù)庫(kù)文件Getfiles.php

 
 
  1. <?php
  2. require_once("DB.php");
  3. function get_user( $name )
  4. {
  5. $dsn = 'mysql://root:password@localhost/bad_multi1';
  6. $db =& DB::Connect( $dsn, array() );
  7. if (PEAR::isError($db)) { die($db->getMessage()); }
  8. $res = $db->query( "SELECT id FROM users WHERE login=?",array( $name ) );
  9. $uid = null;
  10. while( $res->fetchInto( $row ) ) { $uid = $row[0]; }
  11. return $uid;
  12. }
  13. function get_files( $name )
  14. {
  15. $uid = get_user( $name );
  16. $rows = array();
  17. $dsn = 'mysql://root:password@localhost/bad_multi2';
  18. $db =& DB::Connect( $dsn, array() );
  19. if (PEAR::isError($db)) { die($db->getMessage()); }
  20. $res = $db->query( "SELECT * FROM files WHERE user_id=?",array( $uid ) );
  21. while( $res->fetchInto( $row ) ) { $rows[] = $row; }
  22. return $rows;
  23. }
  24. $files = get_files( 'jack' );
  25. var_dump( $files );
  26. ?>

清單 3. Getfiles_good.php

 
 
  1. <?php
  2. require_once("DB.php");
  3. function get_files( $name )
  4. {
  5. $rows = array();
  6. $dsn = 'mysql://root:password@localhost/good_multi';
  7. $db =& DB::Connect( $dsn, array() );
  8. if (PEAR::isError($db)) { die($db->getMessage()); }
  9. $res = $db->query("SELECT files.* FROM users, files WHERE
  10. users.login=? AND users.id=files.user_id",
  11. array( $name ) );
  12. while( $res->fetchInto( $row ) ) { $rows[] = $row; }
  13. return $rows;
  14. }
  15. $files = get_files( 'jack' );
  16. var_dump( $files );
  17. ?>

該代碼不僅更短,而且也更容易理解和高效。我們不是執(zhí)行兩個(gè)查詢(xún),而是執(zhí)行一個(gè)查詢(xún)。盡管該問(wèn)題聽(tīng)起來(lái)有些牽強(qiáng),但是在實(shí)踐中我們通常總結(jié)出所有的表應(yīng)該在同一個(gè)數(shù)據(jù)庫(kù)中,除非有非常迫不得已的理由。


新聞名稱(chēng):快速學(xué)習(xí)PHP數(shù)據(jù)庫(kù)文件使用
URL網(wǎng)址:http://uogjgqi.cn/article/dpicodh.html
掃二維碼與項(xiàng)目經(jīng)理溝通

我們?cè)谖⑿派?4小時(shí)期待你的聲音

解答本文疑問(wèn)/技術(shù)咨詢(xún)/運(yùn)營(yíng)咨詢(xún)/技術(shù)建議/互聯(lián)網(wǎng)交流