成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

快速學習PHP數據庫文件使用

開發 后端
PHP連接數據是最常用的,文章這里詳細的介紹了PHP數據庫文件,希望對大家有技術上的提高。

PHP還是比較常用的,于是我研究了一下PHP數據庫文件,在這里拿出來和大家分享一下,希望對大家有用。我們會看到一個應用程序中,每個表都在一個單獨的數據庫中。在非常大的數據庫中這樣做是合理的,但是對于一般的應用程序,則不需要這種級別的分割。此外,不能跨數據庫執行關系查詢,這會影響使用關系數據庫的整體思想,更不用說跨多個數據庫管理表會更困難了。 那么,多個數據庫應該是什么樣的呢?首先,您需要一些數據。清單 1 展示了分成 4 個文件的這樣的數據。

清單 1. PHP數據庫文件

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

#T#您可以用很多的方式創建數據庫設計、數據庫訪問和基于數據庫的 PHP 業務邏輯代碼,但最終一般以錯誤告終,以及在遇到這些問題時如何修復它們。在這些文件的多數據庫版本中,您應該將 SQL 語句加載到一個數據庫中,然后將 users SQL 語句加載到另一個數據庫中。用于在數據庫中查詢與某個特定用戶相關聯的文件的 PHP 代碼如下所示。get_user 函數連接到包含用戶表的數據庫并檢索給定用戶的 ID。get_files 函數連接到文件表并檢索與給定用戶相關聯的文件行。做所有這些事情的一個更好辦法是將數據加載到一個數據庫中,然后執行查詢,比如下面的查詢。

清單 2. PHP數據庫文件Getfiles.php

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

清單 3. Getfiles_good.php

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

該代碼不僅更短,而且也更容易理解和高效。我們不是執行兩個查詢,而是執行一個查詢。盡管該問題聽起來有些牽強,但是在實踐中我們通常總結出所有的表應該在同一個數據庫中,除非有非常迫不得已的理由。

責任編輯:田樹 來源: 博客
相關推薦

2010-06-02 17:06:54

MySQL數據庫文件

2010-06-09 15:40:59

MySQL數據庫文件

2010-04-22 16:08:24

Oracle數據庫

2011-06-07 10:12:27

2010-05-05 10:19:19

Oracle數據導

2021-03-12 10:12:40

數據庫SQLServer磁盤

2009-03-17 16:00:47

Oracle數據庫備份

2010-09-13 15:21:17

SQL Sever數據

2010-09-25 16:38:34

維護DHCP數據庫文件

2010-04-19 12:16:53

Oracle數據庫

2011-05-20 09:35:24

Oracle數據庫恢復備份

2010-06-09 15:40:59

MySQL數據庫文件

2010-09-13 15:31:14

sql server數

2011-03-24 11:14:46

2009-07-02 14:35:00

Oracle數據庫文件

2010-07-15 17:50:48

SQLServer收縮

2010-06-01 15:46:52

MySQL數據庫文件

2010-03-03 15:45:08

Linux Oracl

2010-04-21 12:13:44

Oracle數據庫

2010-04-28 10:00:10

Oracle數據庫文件
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 99精品国产一区二区三区 | 美女视频一区二区三区 | 天天操天天操 | 国产一区二区观看 | 久久av一区二区三区 | 亚洲a视频 | 99re视频在线观看 | 精品国产99| 在线三级网址 | 欧美精品一区二区三区在线四季 | 国产精品小视频在线观看 | 日韩在线免费播放 | 免费看淫片 | 黄色操视频 | 国产精品视频一区二区三 | 日韩在线大片 | 欧美最猛性xxxxx亚洲精品 | 国产99久久精品一区二区永久免费 | 日本在线免费观看 | 免费一级黄色电影 | 亚州精品天堂中文字幕 | 亚洲字幕在线观看 | 中文字幕av亚洲精品一部二部 | 国产成人精品久久二区二区91 | 天天看天天干 | 久久久久国产精品一区二区 | 91秦先生艺校小琴 | www.日韩| 全免费a级毛片免费看视频免费下 | 精品一区二区三区四区在线 | 国产日韩欧美 | 久草热线| 热久久国产 | 人人鲁人人莫人人爱精品 | 国产精品二区三区 | 九九av| 看片wwwwwwwwwww | 成人性生交大免费 | 精品视频网 | 精品久久一区 | 日韩成人免费中文字幕 |