本文目录一览:
- 1、discuz3.2帖子浏览次数在哪里调用
- 2、discuz数据库调用
- 3、discuz 帖子作者调用代码
- 4、如何调用 discuz的数据 函数操作
- 5、discuz中提到的页面嵌入点和全局嵌入点区别
discuz3.2帖子浏览次数在哪里调用
discuz定义了很多全局变量,熟如调用帖子的浏览数及回复数,可以直接在模板里面这样写:
浏览次数:$_G[forum_thread][views]
回复次数:$_G[forum_thread][replies]
discuz数据库调用
SELECT a.*,b.* FROM pre_forum_thread as a inner join pre_forum_forum as b on a.fid=b.fid
where a.fid40 order by tid desc
discuz 帖子作者调用代码
前面的是作者的uid,后面的是作者。
但是$post[]和$_G[forum_thread][]区别在于后者是全局变量,也就是调用的整个帖子的作者,即楼主,如果调用对应楼层的,那么就是loop循环中使用$post[author]。
如何调用 discuz的数据 函数操作
DB::delete($tablename,
条件,条数限制)删除表中的数据
DB::insert($tablename,
数据(数组),是否返回插入ID,是否是替换式,是否silent)插入数据操作
DB::update($tablename,
数据(数组)条件)更新操作
DB::fetch(查询后的资源)从结果集中取关联数组,注意如果结果中的两个或以上的列具有相同字段名,最后一列将优先。
DB::fetch_first($sql)取查询的第一条数据fetch
DB::fetch_all($sql)查询并fetch
DB::result_first($sql)查询结果集的第一个字段值
DB::query($sql)普通查询
DB::num_rows(查询后的资源)获得记录集总条数
DB::_execute(命令,参数)执行mysql类的命令
DB::limit(n,n)返回限制字串
DB::field(字段名,
$pid)
返回条件,如果为数组则返回
in
条件
DB::order(别名,
方法)排序
注意事项:所有数据在插入数据库之前,均需要进行addslashes()处理,以免特殊字符未经转义在插入数据库的时候出现错误。Discuz!中所有通过
GET,
POST,
FILE,取得的变量默认情况下已经使用了addslashes()进行了转义,不必重复进行。如果数据处理必要(例如用于直接显示),可以使用
stripslashes()
恢复,但数据在插入数据库之前必须再次进行转义。缓存文件中,一般对缓存数据的值采用
addcslashes($string,
'\'\\')进行转义。
discuz中提到的页面嵌入点和全局嵌入点区别
页面嵌入点分为三种类型
1、全局页面嵌入点(一般以global作为前缀,出现在公共模板上)
运行位置:公共模板页面
2、普通页面嵌入点(一般以模块名作为前缀,例如:forum,出现在模块页面上)
运行位置:普通模块模板页面
3、输出前置页面嵌入点
运行位置:模块与模板间,处理数据
页面嵌入点类的命名规则
全局页面嵌入点类(必须)
class plugin_插件标识符{}
普通嵌入点类
class plugin_插件标识符_入口文件名{}
(例如:forum.php?mod=viewthreadtid=1)
class plugin_插件标识符_forum{}