ホームページ >CMS チュートリアル >DEDECMS >DEDECMS SELECT ステートメントの使用方法

DEDECMS SELECT ステートメントの使用方法

藏色散人
藏色散人オリジナル
2020-01-11 09:20:572007ブラウズ

DEDECMS SELECT ステートメントの使用方法

#DEDECMS SELECT ステートメントの使用方法

SQL チュートリアル: SELECT ステートメント DEDECMS インスタンス アプリケーション

推奨学習:

梦Weavercms

DedeCMS システムでは、多くの場面でこれが必要になります。バッチ変更 (置換) コンテンツ、データ コンテンツの呼び出しなど、SQL ステートメントが使用される場所。システム テンプレート内のデータの呼び出しに特に使用されるテンプレート タグ {dede:sql/} があります。テンプレート タグの説明を参照できます。タグの使用方法については、ヘルプセンターをご覧ください。

もちろん、SQL ステートメントを使用および学習する前に、DreamWeaver のデータベース構造を一般的に理解する必要がありますが、これらの内容は、ヘルプセンターのデータベースの説明を通じて簡単に理解できます。

以下は参照されるコンテンツです:

タグ名: sql 機能の説明: SQL クエリを使用してテンプレートから返されたコンテンツを取得するために使用されます 適用範囲: グローバル使用 基本構文: {dede: sql sql=""}基になるテンプレート{/dede:sql} パラメータの説明: sql="" テンプレート フィールドの基になる完全な SQL クエリ ステートメント: SQL ステートメント内で見つかったすべてのフィールドは [field:field name/] で呼び出すことができます

適用例:

1. 特定のメンバーが公開した記事コンテンツを呼び出します

{dede:sql sql='Select * from dede_archives where mid=1'}  
<a href=&#39;/plus/view.php?aid=[field:id/]&#39; target=&#39;_blank&#39;>[field:title/]</a>  
{/dede:sql}

mid はユーザー ID です。dede_archives のデータ テーブル フィールドの導入を参照してください。二次開発

次に、誰もが DedeCMS システムをより良く使用できるように、一般的に使用される SQL ステートメントをいくつか収集して整理します。

SQL ステートメントは、関数呼び出しとコンテンツ呼び出しの 2 つのカテゴリに分類されます。関数型は主にデータベースに対して通常の操作 ({挿入、更新} など) を実行します。データ呼び出し型は (select )、 2 種類の SQL ステートメントの使用と配布も非常に簡単です。関数型の場合は、システムのバックグラウンド [システム]-[SQL コマンド実行ツール] で使用するだけで済みます。データ呼び出し型の場合は、 templateタグは、システムバックグラウンドの[システム]-[SQLコマンド実行ツール]で使用するだけで、テンプレート内の対応する位置にタグを追加するだけです。

関数 SQL ステートメントの構成:

2. 関数の説明: カスタム属性の追加

関連ステートメント:

insert into `dede_arcatt`(sortid,att,attname) values(9,&#39;d&#39;,&#39;评论&#39;);  
alter table `dede_archives` modify `flag` set (&#39;c&#39;,&#39;h&#39;,&#39;p&#39;,&#39;f&#39;,&#39;s&#39;,&#39;j&#39;,&#39;a&#39;,&#39;b&#39;,&#39;d&#39;) default NULL;

3. 関数の説明: Batch is Author andソース割り当て

関連ステートメント:

UPDATE dede_archives SET writer=&#39;要赋的值&#39; WHERE writer=&#39;&#39;;  
UPDATE dede_archives SET source=&#39;要赋的值&#39; WHERE source=&#39;&#39;;

4. 関数の説明: 指定された IP からのコメントの削除

関連ステートメント:

DELETE FROM `dede_フィードバック` WHERE `dede_フィードバック`.`ip` = '000.000.000.000'

000.000.000.000 はスパム コメント発行者の IP です

5. 関数の説明: 記事のキーワード フィールドをクリアします

関連ステートメント:

000.000.000.000 はスパム コメント発行者の IP です

5. 機能の説明: 記事内のキーワード フィールドをクリアします

関連ステートメント:

update dede_archives set keywords=&#39;&#39;

6. 機能の説明: バッチ置換リリース時刻、保管時刻、更新時刻

関連ステートメント:

最初のステップ。背景に記事を追加します。

2009-01-13 14:13:32 など、管理記事から確認できる時刻を取得します。

2 番目のステップは、SQL ステートメント SELECT * FROM dede_archives order by id DESC limit 1 をバックグラウンドで実行することです。

これで、先ほど作成した記事のすべてのフィールド値が表示されます。追加した。

次のデータを確認します。

pubdate: 1231846313

senddate: 1231846313

sortrank: 1231846313

1231846313 は時間データです。

それでは交換です。

UPDATE dede_archives SET sortrank = 1231846313;  
UPDATE dede_archives SET senddate = 1231846313;  
UPDATE dede_archives SET pubdate = 1231846313;

7. 関数の説明: 列を動的または静的にバッチ変更する

関連ステートメント:

UPDATE `dede_arctype` SET `isdefault` = &#39;-1&#39; 动态 
UPDATE `dede_arctype` SET `isdefault` = &#39;1&#39; 静态

8. 関数の説明: SQL ステートメントを記事のコンテンツにバッチ置換

関連ステートメント:

update `dede_addonarticle` set body=REPLACE(body,&#39;论坛&#39;,&#39;社区&#39;) where body like "%论坛%"

上記の SQL ステートメントの機能は、「フォーラム」という語句を含むすべての記事を検索し、フォーラムを「コミュニティ」に置き換えることです。

データ呼び出し SQL ステートメント組織:

9. タグの説明: 共通コンテンツ統計コード

関連タグ:

共有文章:** 篇  
{dede:sql sql="select count(*) as c from dede_archives where channel=1"}·共有文章:[field:c /]篇{/dede:sql}  
·共有图集:** 个  
{dede:sql sql="select count(*) as c from dede_archives where channel=2"}·共有图集:[field:c /]个{/dede:sql}  
·共有软件:** 个  
{dede:sql sql="select count(*) as c from dede_archives where channel=3"}·共有软件:[field:c /]个{/dede:sql}  
·共有评论:**条  
{dede:sql sql="select count(*) as c from dede_feedback"}·共有评论:[field:c /]条{/dede:sql}  
·共有会员:**名  
{dede:sql sql="select count(mid) as c from dede_member "}·共有会员:[field:c /]名{/dede:sql}  
·文章阅读:** 人次  
{dede:sql sql="select sum(click) as c from dede_archives"}文章阅读:[field:c /]人次{/dede:sql}  
·今日更新:**篇  
{dede:sql sql="SELECT count( * ) AS c FROM dede_archives WHERE pubdate > UNIX_TIMESTAMP( CURDATE( ) ) "}今日更新:[field:c /]篇{/dede:sql} 
总共留言:{dede:sql sql="select count(*) as cc From dede_guestbook"}[field:cc/]{/dede:sql}条


10. 呼び出し手順: Call the Discuz画像付きのフォーラム添付ファイル 投稿

関連タグ:

{dede:sql sql="SELECT` cdb_p_w_uploads`.`aid`, `cdb_p_w_uploads`.`p_w_upload`,`cdb_threads`.`tid`, `cdb_threads`.`fid`, `cdb_threads`.`subject` FROM `cdb_p_w_uploads` LEFT JOIN `cdb_threads` ON `cdb_threads`.`tid`=`cdb_p_w_uploads`.`tid` WHERE `cdb_p_w_uploads`.`readperm`=&#39;0&#39; AND `displayorder`>=&#39;0&#39; AND `filetype`=&#39;p_w_picpath/pjpeg&#39; GROUP BY tid LIMIT 0,2"}  
<li><A href="/bbs/viewthread.php?tid=[field:tid /]"><IMG src="/bbs/p_w_uploads/[field:p_w_upload/]"></A></li>  
<li><A href="/bbs/viewthread.php?tid=[field:tid /]">[field:subject function="cn_substr(&#39;@me&#39;,30)" /]</A></li>  
{/dede:sql}

11. 電話の指示: UCHOME 最新ログに電話する

関連タグ:

{dede:sql sql="Select subject,viewnum,blogid,uid From uchome_blog order by blogid desc limit 0,8"}  
<li><A href="?uid=[field:uid/]&do=blog&id=[field:blogid/]">[field:subject function="cn_substr(&#39;@me&#39;,24)" /]</A></li>  
{/dede:sql}

12. 電話の指示:会員ポイントランキング

関連タグ:

{dede:sql sql="Select mid,userid,uname,scores From dede_member order by scores desc limit 0,10"}  
<dd><span class="name"><a href=&#39;[field:global/]/member/?[field:userid/]/&#39;>[field:uname/]</a>  
</span><span class="jifen">积分[field:scores/]</span></dd>  
{/dede:sql}

以上がDEDECMS SELECT ステートメントの使用方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。