當前位置:首頁 » 數據倉庫 » phpcms資料庫結構
擴展閱讀
webinf下怎麼引入js 2023-08-31 21:54:13
堡壘機怎麼打開web 2023-08-31 21:54:11

phpcms資料庫結構

發布時間: 2022-08-06 19:23:44

❶ 求phpcms v9的資料庫增刪改查 是怎麼實現的

表明默認當前load_model('xxxx')模塊所在表名xxxx
若要指定表名 則:操作在mysql.class.php中$this->db->select(...)
1、查詢
$this->select($where = '', $data = '*', $limit = '', $order = '', $group = '', $key='') 返回結果集數組
條件 ,欄位(id,name,email....),范圍 排序方式,分組方式,按建名排序
2、查詢多條數據並分頁
listinfo($where = '', $order = '', $page = 1, $pagesize = 20, $key='', $setpages = 10,$urlrule = '',$array = array())
3、獲取單條記錄查詢
get_one($where = '', $data = '*', $order = '', $group = '')
4、直接執行sql查詢
query($sql);
5、獲取最後一次添加記錄的主鍵號 insert_id()
6、執行更新記錄操作 update($data, $where = '') $data 建議為數組,$where 可為數組可為字元串
7、執行刪除記錄操作 delete($where)
8、計算記錄數 count($where = '')
9、獲取最後資料庫操作影響到的條數 affected_rows()
10、獲取數據表主鍵 get_primary()
11、獲取表欄位 get_fields($table_name = '')
12、檢查表是否存在 table_exists($table)
13、 檢查欄位是否存在 field_exists($field)
更多問題可以去php中文網問答社區提問,大神在線幫你解決,希望對你有幫助

❷ 在phpcms後台怎麼增加模塊

【1】創建模塊目錄
通過前面的學習,我們已經知道phpcms V9框架中的模塊位於phcms/moles目錄中,每一個目錄稱之為一個模塊。
如果要創建一個模塊,只要在 phpcms/moles 目錄下創建文件夾並放入你的控制器類就可以了。
例如我要開發一個叫做test的模塊,那麼首先在 phpcms/moles 目錄下創建文件夾,並將其命名為test。
觀察其他模塊的結構,可知test模塊的標准結構通常應該也是這樣的:
classes 為模塊類庫包
functions 為模塊函數庫包
templates 為模塊模板包,通常放置含有許可權控制的控制器模板,也就是後台模板。
如果你的模板有自定義的前台模板,你需要在phpcms\templates\default目錄下創建一個你的模塊名目錄來放置前台模板,「default」為你的風格包名稱,我們默認是用default。
【2】創建模塊控制器類
上一步,我們已經創建好了一個名為test的模塊,接下來我們繼續為這個模塊添加兩個控制器類。
phpcms V9 的控制器就是模塊的類文件,位於phpcms/moles/模塊名/目錄下面。類文件名稱就是控制器名+.php,例如一個名為mytest的控制器,那麼它的命名為mytest.php即可。控制器類默認繼承系統的函數庫,可以直接使用。
控制器類的類名稱與控制器文件名必須相同。
控制器類文件包含兩種形式:
1.前台瀏覽(不含許可權控制),mytest.php 控制器
在phpcms/moles/test 目錄下,新建文本文件,命名為mytest,修改文件類型為php, 用Notepad++打開編輯內容為:
1 <?php
2 defined('IN_PHPCMS') or exit('No permission resources.');
3 class mytest
4 {
5 function __construct(){}
6 public function init()
7 {
8 $myvar = 'hello world!';
9 echo $myvar;
10 }
11 public function mylist()
12 {
13 $myvar = 'hello world! This is an example!';
14 echo $myvar;
15 }
16 }
17 ?>
其實,這個控制器的URL訪問方法前面已經介紹過,請參見《phpcms V9 MVC模式與URL訪問解析》
http://www.abcd.com.cn/phpcms/index.php?m=test&c=mytest等價於
http://www.abcd.com.cn/phpcms/index.php?m=test&c=mytest&a=init。
沒有填寫「a」值的情況下,默認調用init方法。
為什麼這樣子?請把《phpcms V9 MVC模式與URL訪問解析》再讀一遍。
2.後台管理(含許可權控制),mytest_admin.php 控制器
後台控制器需要載入admin模塊下的admin類,並繼承該類。需要注意的是因為添加的控制器類繼承了其它的類,要小心控制器類的方法名不要和該類中的方法名一樣了,否則會造成影響,具體請查看admin類中有哪些方法。
在phpcms/moles/test 目錄下,新建文本文件,命名為mytest_admin,修改文件類型為php, 用Notepad++打開編輯內容為:
1 <?php
2 defined('IN_PHPCMS') or exit('No permission resources.');
3 pc_base::load_app_class('admin','admin',0);
4 class mytest_admin extends admin
5 {
6 public function __construct() {}
7 public function init()
8 {
9 $myvar = 'oh,i am phpcmser';
10 echo $myvar;
11 }
12 }
13 ?>
在控制器中增加模板調用
phpcms 可以實現完全的模板與程序分離,所以在我們的控制器程序中要載入模板,才可以更友好的顯示出來。
1.載入前台模板
前台模板文件在phpcms\templates\default\模塊名稱的目錄中,本示例也就在phpcms\templates\default\test中。
載入模板方法如下:
1 // 載入模板方法:
2 include template('test', 'mytest', 'default');
其中,test為模塊名稱,mytest為模板目錄下模板名稱,default為風格名稱,默認為default。
在上面例子中如果要給mytest.php中init方法載入一個mytest的模板(可以拷貝content模塊下的index.html作為替代),如下(所以模板名稱為index):
1 public function init()
2 {
3 $myvar = 'hello world!';
4 echo $myvar;
5 include template('test', 'index');
6 }
這時,當我們再通過URL訪問該方法的時候也就載入了對應的模板。
2.載入後台模板
後台模板文件在phpcms\moles\模塊名稱\templates 目錄中,本示例也就在phpcms\moles\test\templates中
載入模板方法如下:
// 載入模板方法:
include $this->admin_tpl('mytest_admin_list');
其中mytest_admin_list為phpcms\moles\test\templates中mytest_admin_list.tpl.php。
注意:此處模板必須以.tpl.php 作為後綴
在上面例子中如果要給mytest_admin.php中init方法載入一個mytest_admin_list的模板,如下:
1 public function init()
2 {
3 $myvar = 'oh,i am phpcmser';
4 echo $myvar;
5 include $this->admin_tpl('mytest_admin_list');
6 }
載入模板部分內容也可以參見系統框架源碼content模塊 phpcms\moles\content content.php文件的實現。
【3】創建資料庫模型類
至此,已經明確,各模塊的資料庫模型位於:phpcms/model/ 目錄下。
數據模型文件的命名規則建議為:數據表名稱 + '_model.class.php'
如果在我們的創建的模塊中我要使用一個資料庫「test」,首先需要建立一個資料庫模型文件,文件名稱為'test_model.class.php'
內容如下:
1 <?php
2 defined('IN_PHPCMS') or exit('No permission resources.');
3 pc_base::load_sys_class('model', '', 0);
4 class test_model extends model
5 {
6 public function __construct()
7 {
8 $this->db_config = pc_base::load_config('database');
9 $this->db_setting = 'default';
10 $this->table_name = 'test';
11 parent::__construct();
12 }
13 }
14 ?>
書寫資料庫模型類注意一下幾點:
1. 資料庫模型類名稱必須與文件名稱相同。
2. 必須繼承與資料庫模型基類model。
3. $this->db_setting = 'default'為資料庫配置文件中配置資料庫鏈接池名稱,默認為default,一般情況下不需要修改。
4. $this->table_name = 'test'為數據表名稱。
這樣我們就建立好一個資料庫模型類。那麼,怎麼使用呢?
在模塊的控制器中使用(載入方式):
$this->db = pc_base::load_model('test_model');
具體如下:
1 <?php
2 defined('IN_PHPCMS') or exit('No permission resources.');
3 class mytest
4 {
5 private $db;
6 function __construct()
7 {
8 $this->db = pc_base::load_model('test_model'); // 載入資料庫模型
9 }
10 public function init()
11 {
12 $myvar = 'hello world!';
13 echo $myvar;
14 include template('test', 'index');
15 $result = $this->db->select(); // 調用select方法
16 var_mp($result);
17 }
18 public function mylist()
19 {
20 $myvar = 'hello world! This is an example!';
21 echo $myvar;
22 }
23 }
24 ?>
其中$this->db中所支持的方法請參照父類 phpcms/libs/classes/model.class.php 中方法。

❸ 如何修改phpcms的資料庫配置

主你好 PHPCMS V9資料庫配置文件database.php位置在根目錄\caches\configs 下,網站搬家或者資料庫連不上的時候都可以修改這里。

❹ phpcms 操作兩個資料庫

要麼使用外部資料庫,要麼調用一個介面,在那個介面中寫入插入數據操作

❺ phpcms怎麼導入資料庫內容

方法一:使用資料庫管理軟體(如navicat、mysqladmin)等直接導入;
方法二:使用phpcms的後台進行備份與備份數據的導入,具體操作為:後台-擴展-資料庫工具-資料庫導入界面,選定已備份的數據進行導入操作。

❻ phpcmsv9 使用的是什麼資料庫

NSArray *indexPathsForVisibleRows = [detailTableView indexPathsForVisibleRows];
NSMutableSet *sectionSet = [NSMutableSet set];
for ( NSIndexPath *indexPath in indexPathsForVisibleRows ) {
[sectionSet addObject:[NSNumber numberWithInt:indexPath.section]];
}
NSLog(@"sectionSet %@",sectionSet);
// sectionSet {(13, 11, 9, 10, 12 )}

❼ 怎麼創建PHPCMS模塊

一.分析一下資料庫結構,這些模板都安裝到那個數據表中。

1.mole表,在表中位元組mole和name可以看到安裝的模板。
2.menu表,這個表中放的的模板中的功能函數,對應鏈接中的a.

二.分析一下模板所要涉及到的文件目錄。

1.在phpcms\moles目錄中,可以看到模板的目錄,對應的目錄名就是它的模板英文名稱。

2.在phpcms\model目錄中,對用模板model表中的資料庫連接文件。

拿點評那個文件舉例

<?php
defined('IN_PHPCMS') or exit('No permission resources.');
pc_base::load_sys_class('model', '', 0);
class dianping_model extends model {
function __construct() {
$this->db_config = pc_base::load_config('database');
$this->db_setting = 'default';
$this->table_name = 'dianping';
parent::__construct();
}
}
?>

如果安裝屬於自已的模塊的話,安照以上格式進行更改,把dianping_model改成和文件名一致,把$this->table_name = 'dianping';後面的dianping

改成表名。

3.在caches\configs目錄中,moles.php可以看到所安裝的模塊,以函數方式表示。

4.在phpcms\languages\zh-cn目錄中,system_menu.lang.php放著系統中對應的操作名稱。

三.分析一下模板目錄。

1.install和uninstal表示安裝和卸載目錄。

2.在根目錄中和index.php文件,這個文件表示前台頁面,裡面放有對應頁面函數。

3.後台文件,這個名稱和一般和目錄名稱一樣,裡面放有對應後台函數。

4.templates目錄,裡面放有後台頁面。

5.function目錄,裡面可以放一些關於此模板功能的函數。

6.classes目錄,裡面為class.php文件放有模板的標簽類。

7.在phpcms\templates\default目錄,會放一個和模板同名的文件夾表示它的前台頁面

四.操作流程。

1.安裝目錄install,裡面有三個文件分別為model.php,extention.inc.php,config.inc.php這三個文件分別表示,model.php要成生的模板函數名,extention.inc.php安裝操作函數名,後面'display'=>'1'表示在後台導航中顯示,$language這個表示對應的名稱。config.inc.php,模塊信息,在安裝時會彈出提示說明就是這個文件。

2.在這install目錄中會有sql文件,這個表示要生成的資料庫表sql語句。在安裝中系統會自動讀取這些sql文件,生成模塊中所要的資料庫表。

3.languages和templates表示語言包和前台頁面,不做說明

4.uninstal,是卸載文件目錄,和install目錄對應。

5.當完成了安裝目錄install時,可以進行安裝試一下,當然在這過程中一定會遇到些問題,細心調試就會成功的。

6,安照前三點分析,寫出自己的後台文件,和前台文件,就可以做成一個以屬於自己怕模板功能。在這里提示一下,在寫一個模板時,要細心的規劃一下表結構,功能要求,整個流程,這樣才能寫出一個完美的功能模塊。