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
- define(`IN_ECS`, true);
- define(`EC_CHARSET`, `utf-8`);
- define(`ROOT_PATH`, `D:/Program Files/Zend/Apache2/htdocs/ecshop/`);
- define(`DATA_DIR`, `data`);
- $db_host = “localhost:3306”;
- $db_name = “ecshop”;
- $db_user = “root”;
- $db_pass = “”;
- require(`../includes/cls_mysql.php`);
- $db = new cls_mysql($db_host, $db_user, $db_pass, $db_name);
獲取所有記錄
getAll方法用來從資料庫中獲取滿足條件的所有記錄。getAllCached是它的快取版本,cache key是該方法的第二個引數,如果快取有效,直接返回快取結果,否則重新執行資料庫查詢。
將下面的程式碼加到test_mysql.php的最後:
- test_getAll();
- function test_getAll()
- {
- global $db;
- $sql = “SELECT user_id, user_name, email FROM ecs_admin_user”;
- $result = $db->getAll($sql);
- print_r($result);
- }
修改以後的test_mysql.php執行結果如下:
- Array
- (
- [0] => Array
- (
- [user_id] => 1
- [user_name] => admin
- [email] => admin@admin.com
- )
- [1] => Array
- (
- [user_id] => 2
- [user_name] => bjgonghuo1
- [email] => bj@163.com
- )
- [2] => Array
- (
- [user_id] => 3
- [user_name] => shhaigonghuo1
- [email] => shanghai@163.com
- )
- [3] => Array
- (
- [user_id] => 4
- [user_name] => amonest
- [email] => amonest@foxmail.com
- )
- )
獲取單行記錄
getRow方法用來從資料庫中獲取滿足條件的單行記錄,或者說是第一條記錄。getRowCached是它的快取版本,cache key是該方法的第二個引數,如果快取有效,直接返回快取結果,否則重新執行資料庫查詢。
將下面的程式碼加到test_mysql.php的最後:
- test_getRow();
- function test_getRow()
- {
- global $db;
- $sql = “SELECT user_id, user_name, email FROM ecs_admin_user LIMIT 1”;
- $result = $db->getRow($sql);
- print_r($result);
- }
修改以後的test_mysql.php執行結果如下:
- Array
- (
- [user_id] => 1
- [user_name] => admin
- [email] => admin@admin.com
- )
獲取某欄位的所有值
getCol方法用來從資料庫中獲取滿足條件的某個欄位的所有值。getColCached是它的快取版本,cache key是該方法的第二個引數,如果快取有效,直接返回快取結果,否則重新執行資料庫查詢。
將下面的程式碼加到test_mysql.php的最後:
- test_getCol();
- function test_getCol()
- {
- global $db;
- $sql = “SELECT email FROM ecs_admin_user”;
- $result = $db->getCol($sql);
- print_r($result);
- }
修改以後的test_mysql.php執行結果如下:
- Array
- (
- [0] => admin@admin.com
- [1] => bj@163.com
- [2] => shanghai@163.com
- [3] => amonest@foxmail.com
- )
獲取單個值
getOne方法用來從資料庫中獲取滿足條件的單個值。getOneCached是它的快取版本,cache key是該方法的第二個引數,如果快取有效,直接返回快取結果,否則重新執行資料庫查詢。
將下面的程式碼加到test_mysql.php的最後:
- test_getOne();
- function test_getOne()
- {
- global $db;
- $sql = “SELECT email FROM ecs_admin_user WHERE user_id = 4”;
- $result = $db->getOne($sql);
- print_r($result);
- }
修改以後的test_mysql.php執行結果如下:
執行資料庫查詢
query方法用來執行資料庫查詢,例如INSERT,UPDATE,DELETE等。
將下面的程式碼加到test_mysql.php的最後:
- test_query();
- function test_query()
- {
- global $db;
- $sql = “UPDATE ecs_admin_user SET todolist = `你有一封新郵件!` WHERE user_id = 4”;
- $db->query($sql);
- $sql = “SELECT todolist FROM ecs_admin_user WHERE user_id = 4”;
- $result = $db->getOne($sql);
- print_r($result);
- }
修改以後的test_mysql.php執行結果如下:
資料庫表操作
autoExecute方法用來簡化對資料表的INSERT和UPDATE。
將下面的程式碼加到test_mysql.php的最後:
- test_autoExecute();
- function test_autoExecute()
- {
- global $db;
- $table = “ecs_role”;
- $field_values = array(“role_name” => “總經理辦”, “role_describe” => “總經理辦”, “action_list” => “all”);
- $db->autoExecute($table, $field_values, “INSERT”);
- // 執行的SQL:INSERT INTO ecs_role (role_name, action_list, role_describe) VALUES (`總經理辦`, `all`, `總經理辦`)
- $role_id = $db->insert_id(); // 新記錄的ID:5
- $field_values = array(“action_list” => “goods_manage”);
- $db->autoExecute($table, $field_values, “UPDATE”, “role_id = $role_id”);
- // 執行的SQL:UPDATE ecs_role SET action_list = `goods_manage` WHERE role_id = 5
- $sql = “SELECT action_list FROM ecs_role WHERE role_id = $role_id”;
- $result = $db->getOne($sql);
- print_r($result);
- }
修改以後的test_mysql.php執行結果如下:
- goods_manage
相關文章
- 運算元據庫
- 運算元據庫表
- jmeter運算元據庫JMeter
- DDL:運算元據庫
- Python運算元據庫(3)Python
- 利用 Sequelize 來運算元據庫
- java 運算元據庫備份Java
- Python學習:運算元據庫Python
- [python] 基於Dataset庫運算元據庫Python
- Android中使用LitePal運算元據庫Android
- Django在Ubuntu下運算元據庫DjangoUbuntu
- python運算元據Python
- 肖sir__jmeter之運算元據庫JMeter
- 資料庫誤運算元據恢復資料庫
- 教你如何用python運算元據庫mysql!!PythonMySql
- MySQL DML運算元據MySql
- 如何讓Designer更好地運算元據庫物件物件
- lavavel 中運算元據庫查詢別名
- spring-boot-route(九)整合JPA運算元據庫Springboot
- spring-boot-route(七)整合jdbcTemplate運算元據庫SpringbootJDBC
- spring-boot-route(八)整合mybatis運算元據庫SpringbootMyBatis
- uniapp單機軟體運算元據庫(安卓)APP安卓
- Go語言運算元據庫及其常規操作Go
- Oracle OCP(10):運算元據Oracle
- 好程式設計師分享DDL之運算元據庫程式設計師
- sql運算元據庫(2)--->DQL、資料庫備份和還原SQL資料庫
- HelloDjango 系列教程:第 04 篇:Django 遷移、運算元據庫Django
- Golang 學習系列第四天:運算元據庫 PostgreSQLGolangSQL
- Pandas 基礎 (19) - 運算元據庫 (read_sql, to_sql)SQL
- 【Spark篇】---SparkStreaming中運算元中OutPutOperator類運算元Spark
- 一文快速回顧 Java 運算元據庫的方式-JDBCJavaJDBC
- 到底應該先操作快取還是先運算元據庫?快取
- Oracle delete誤運算元據恢復(BBED)Oracledelete
- 透過延時從庫+binlog複製,恢復誤運算元據
- 併發環境下,先運算元據庫還是先操作快取?快取
- 分散式高效能狀態與原子運算元據庫slock簡介分散式
- 好程式設計師Java培訓分享JDBC運算元據庫的步驟程式設計師JavaJDBC
- Spark----RDD運算元分類 DAGSpark
- Spring Boot入門系列(十四)使用JdbcTemplate運算元據庫,配置多資料來源!Spring BootJDBC