ecshop操作數據庫類


ECShop v2.7.2沒有使用一些開源的數據庫操作類,比如adodb或者PEAR,而是封裝了自己的實現。這樣做的好處是實現非常輕量,只有一個文件,27Kb,大大減小了分發包的文件大小。另外,當網站需要做memcached緩存時,也可以很方便的實現。當然,這樣做的后果就是數據庫的選擇非常狹窄,無法實現其它的非MySQL數據庫。

 

ECShop的數據操作類文件是includes/cls_mysql.php,類名是cls_mysql。該類主要提供了下面 一些比較有用的方法:

  • getAll($sql)和getAllCached($sql, $cached = 'FILEFIRST'):獲取所有記錄。
  • getRow($sql, $limited = false)和getRowCached($sql, $cached = 'FILEFIRST'):獲取單行記錄。
  • getCol($sqlse)和getColCached($sql, $cached = 'FILEFIRST'):獲取某欄位的所有值。
  • getOne($sql, $limited = false)和getOneCached($sql, $cached = 'FILEFIRST'):獲取單個數值。
  • query($sql):執行數據庫查詢。
  • autoExecute($table, $field_values, $mode = 'INSERT', $where = ''):數據庫表操作。

現在我們以實例的方式來說明這些方法如何使用。首先,在ecshop/admin目錄下新增文件test_mysql.php,文件內容如下:

[php]   view plain copy
  1. <?php  
  2.   
  3. define('IN_ECS', true);   
  4. define('EC_CHARSET''utf-8');  
  5. define('ROOT_PATH''D:/Program Files/Zend/Apache2/htdocs/ecshop/');  
  6. define('DATA_DIR''data');  
  7.   
  8. $db_host = "localhost:3306";   
  9. $db_name = "ecshop";   
  10. $db_user = "root";   
  11. $db_pass = "";   
  12.   
  13. require('../includes/cls_mysql.php');   
  14. $db = new cls_mysql($db_host$db_user$db_pass$db_name);  

 

 

 


 

 獲取所有記錄

getAll方法用來從數據庫中獲取滿足條件的所有記錄。getAllCached是它的緩存版本,cache key是該方法的第二個參數,如果緩存有效,直接返回緩存結果,否則重新執行數據庫查詢。

 

將下面的代碼加到test_mysql.php的最后:

 

[php]   view plain copy
  1. test_getAll();  
  2.   
  3. function test_getAll()  
  4. {  
  5.     global $db;  
  6.       
  7.     $sql = "SELECT user_id, user_name, email FROM ecs_admin_user";  
  8.     $result = $db->getAll($sql);  
  9.     print_r($result);  
  10. }  

 

修改以后的test_mysql.php執行結果如下:

 

[php]   view plain copy
  1. Array  
  2. (  
  3.     [0] => Array  
  4.         (  
  5.             [user_id] => 1  
  6.             [user_name] => admin  
  7.             [email] => admin@admin.com  
  8.         )  
  9.   
  10.     [1] => Array  
  11.         (  
  12.             [user_id] => 2  
  13.             [user_name] => bjgonghuo1  
  14.             [email] => bj@163.com  
  15.         )  
  16.   
  17.     [2] => Array  
  18.         (  
  19.             [user_id] => 3  
  20.             [user_name] => shhaigonghuo1  
  21.             [email] => shanghai@163.com  
  22.         )  
  23.   
  24.     [3] => Array  
  25.         (  
  26.             [user_id] => 4  
  27.             [user_name] => amonest  
  28.             [email] => amonest@foxmail.com  
  29.         )  
  30.   
  31. )  

 

 

 


 

 獲取單行記錄

getRow方法用來從數據庫中獲取滿足條件的單行記錄,或者說是第一條記錄。getRowCached是它的緩存版本,cache key是該方法的第二個參數,如果緩存有效,直接返回緩存結果,否則重新執行數據庫查詢。

 

將下面的代碼加到test_mysql.php的最后:

 

[php]   view plain copy
  1. test_getRow();  
  2.   
  3. function test_getRow()  
  4. {  
  5.     global $db;  
  6.       
  7.     $sql = "SELECT user_id, user_name, email FROM ecs_admin_user LIMIT 1";  
  8.     $result = $db->getRow($sql);  
  9.     print_r($result);  
  10. }  

 

修改以后的test_mysql.php執行結果如下:

 

[php]   view plain copy
  1. Array  
  2. (  
  3.     [user_id] => 1  
  4.     [user_name] => admin  
  5.     [email] => admin@admin.com  
  6. )  

 

 

 


 

 獲取某欄位的所有值

getCol方法用來從數據庫中獲取滿足條件的某個欄位的所有值。getColCached是它的緩存版本,cache key是該方法的第二個參數,如果緩存有效,直接返回緩存結果,否則重新執行數據庫查詢。

 

將下面的代碼加到test_mysql.php的最后:

 

[php]   view plain copy
  1. test_getCol();  
  2.   
  3. function test_getCol()  
  4. {  
  5.     global $db;  
  6.       
  7.     $sql = "SELECT email FROM ecs_admin_user";  
  8.     $result = $db->getCol($sql);  
  9.     print_r($result);  
  10. }  

 

修改以后的test_mysql.php執行結果如下:

 

[php]   view plain copy
  1. Array  
  2. (  
  3.     [0] => admin@admin.com  
  4.     [1] => bj@163.com  
  5.     [2] => shanghai@163.com  
  6.     [3] => amonest@foxmail.com  
  7. )  

 

 

 


 

 獲取單個值

getOne方法用來從數據庫中獲取滿足條件的單個值。getOneCached是它的緩存版本,cache key是該方法的第二個參數,如果緩存有效,直接返回緩存結果,否則重新執行數據庫查詢。

 

將下面的代碼加到test_mysql.php的最后:

 

[php]   view plain copy
  1. test_getOne();  
  2.   
  3. function test_getOne()  
  4. {  
  5.     global $db;  
  6.       
  7.     $sql = "SELECT email FROM ecs_admin_user WHERE user_id = 4";  
  8.     $result = $db->getOne($sql);  
  9.     print_r($result);  
  10. }  

 

修改以后的test_mysql.php執行結果如下:

 

 

 

 


 

 執行數據庫查詢

query方法用來執行數據庫查詢,例如INSERT,UPDATE,DELETE等。 

將下面的代碼加到test_mysql.php的最后:

 

[php]   view plain copy
 
  1. test_query();  
  2.   
  3. function test_query()  
  4. {  
  5.     global $db;  
  6.       
  7.     $sql = "UPDATE ecs_admin_user SET todolist = '你有一封新郵件!' WHERE user_id = 4";  
  8.     $db->query($sql);  
  9.     $sql = "SELECT todolist FROM ecs_admin_user WHERE user_id = 4";  
  10.     $result = $db->getOne($sql);  
  11.     print_r($result);  
  12. }  

 

修改以后的test_mysql.php執行結果如下:

 

 

 

 


 

 數據庫表操作

autoExecute方法用來簡化對數據表的INSERT和UPDATE。 

將下面的代碼加到test_mysql.php的最后:

 

[php]   view plain copy
 
  1. test_autoExecute();  
  2.   
  3. function test_autoExecute()  
  4. {  
  5.     global $db;  
  6.       
  7.     $table = "ecs_role";  
  8.     $field_values = array("role_name" => "總經理辦""role_describe" => "總經理辦""action_list" => "all");  
  9.     $db->autoExecute($table$field_values"INSERT");  
  10.     // 執行的SQL:INSERT INTO ecs_role (role_name, action_list, role_describe) VALUES ('總經理辦', 'all', '總經理辦')  
  11.   
  12.     $role_id = $db->insert_id(); // 新記錄的ID:5  
  13.       
  14.     $field_values = array("action_list" => "goods_manage");  
  15.     $db->autoExecute($table$field_values"UPDATE""role_id = $role_id");  
  16.     // 執行的SQL:UPDATE ecs_role SET action_list = 'goods_manage' WHERE role_id = 5  
  17.   
  18.     $sql = "SELECT action_list FROM ecs_role WHERE role_id = $role_id";  
  19.     $result = $db->getOne($sql);  
  20.     print_r($result);  
  21. }  

 

修改以后的test_mysql.php執行結果如下:

 

[php]   view plain copy
  1. goods_manage  

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM