讓dede執行php程式碼和mysql語句

神馬和浮雲發表於2014-02-19

一、dede執行php程式碼

舉例1:

{dede:name runphp='yes'}
$str = "hello ";
@me = $str;
@me .= "world";
{/dede:name}

結果:hello world

說明:"name"為任意定義的名字,@me 表示當前的值,也就是要輸出最後一個@me的值。


 

舉例2

{dede:field runphp='yes'}
$str = "world";
$DedeMeValue="hello ";
$DedeMeValue .= $str;
{/dede:field}

結果:hello world

說明:如果直接引入PHP並要獲得執行後的值,必須用 $DedeMeValue 表示執行這個PHP後最終返回的值(因此不能用HTML混合的寫法)


 

舉例3

{dede:list perpage='10'}
[field:id runphp="yes"]
$dsql = new DedeSql(false);
$a="select a.address FROM dede_addonarticle as a where a.aid=@me";
$arcRow = $dsql->GetOne($a);
@me=''.$arcRow[address].'';
[/field:id]
{/dede:list}


 

二、引用php檔案(在網上看到的,沒有親自試驗)

如果你想在include的檔案中使用PHP,則加上 source='value'

{dede:include runphp='yes' source='value' file=''/}


三、 dede執行mysql語句

舉例1

{dede:sql sql="SELECT COUNT(*) AS nums FROM dede_addonarticle"}
[field:name = "nums"/]
{/dede:sql}

輸出的就是dede_addonarticle表的nums欄位的值,查詢出幾條就輸出幾次


 

舉例2

{dede:sql sql="SELECT * FROM dede_archives WHERE writer=~writer~"}
[field:id/]
{/dede:sql}

說明:~writer~為變數。如,在內容頁模版中,呼叫的是a表,a表中有欄位writer=xc,那麼上面那條語句在這個內容頁模板中就相當於SELECT * FROM dede_archives WHERE writer='xc',[field:id/]就是資料庫dede_archives中的id欄位

 

 

相關文章