本帖最后由 ziluopao3 于 2014-09-25 15:41:13 编辑

解决方案 »

  1.   

    本人也是个菜鸟,最开始遇到过变白的原因变量没加 $,后来是函数声明的那个文件没有引进来。。自己在认为可能有错的地方 echo "" 一些东西,看看具体是哪错了,慢慢试把。。
      

  2.   

    建discuz的入口文件,只需要如下两句require_once './source/class/class_core.php';
    C::app()->init();你没有C::app()->init();
      

  3.   

    可是我都加了,这是其一,另外你说慢慢试试,用不着提醒吧,象这种没啥意思的帖子尽量别回.有意义吗?
    sorry
      

  4.   

    <?php/**
     *      [Discuz!] (C)2001-2099 Comsenz Inc.
     *      This is NOT a freeware, use is subject to license terms
     *
     *      $Id: forum.php 33828 2013-08-20 02:29:32Z nemohou $
     */
    define('APPTYPEID', 88);
    define('CURSCRIPT', 'test');
    require './source/class/class_core.php';
    require './source/function/function_forum.php';C::app()->init();$siteuniqueid = C::t('portal_category')->fetch('catname');
    while($value=DB::fetch($siteuniqueid)){
    $data[]=$value;
    }
    print_r($data);?>
    我这样加上了,还是打印不出来,空白,没有提示报错
      

  5.   

    $siteuniqueid = C::t('portal_category')->fetch('catname');
    fetch括号里面只能是主键id,也就说只能为数字(可以查看\source\class\discuz\discuz_table.php里面的fetch)
    用C类执行后不需要,返回的不是资源类型,你不需要用DB::fetch
    实际上只有用DB::query查询的语句,返回的才是资源类型
    所以,你应该改为:
    $data = C::t('portal_category')->fetch(1);
    print_r($data);
      

  6.   

    这回行了,下面是正确的代码,还有一点有疑惑:你说实际上只有用DB::query查询的语句,返回的才是资源类型
    但是我的代码中没有去掉DB::query为啥还能正确打印呢
    <?php/**
     *      [Discuz!] (C)2001-2099 Comsenz Inc.
     *      This is NOT a freeware, use is subject to license terms
     *
     *      $Id: forum.php 33828 2013-08-20 02:29:32Z nemohou $
     */
    define('APPTYPEID', 88);
    define('CURSCRIPT', 'test');
    require './source/class/class_core.php';
    require './source/function/function_forum.php';C::app()->init();$data = C::t('portal_category')->fetch(1);
    while($value=DB::fetch($siteuniqueid)){
    $data[]=$value;
    }
    print_r($data);?>
      

  7.   

    你在fetch(1)中放的是1,如果我想把这个表中所有的数据都打印出来怎么办呢
    我试着写fetch('catid'')
    显示的打印结果是Array呢
      

  8.   

    这回行了,下面是正确的代码,还有一点有疑惑:你说实际上只有用DB::query查询的语句,返回的才是资源类型
    但是我的代码中没有去掉DB::query为啥还能正确打印呢
    <?php/**
     *      [Discuz!] (C)2001-2099 Comsenz Inc.
     *      This is NOT a freeware, use is subject to license terms
     *
     *      $Id: forum.php 33828 2013-08-20 02:29:32Z nemohou $
     */
    define('APPTYPEID', 88);
    define('CURSCRIPT', 'test');
    require './source/class/class_core.php';
    require './source/function/function_forum.php';C::app()->init();$data = C::t('portal_category')->fetch(1);
    while($value=DB::fetch($siteuniqueid)){
    $data[]=$value;
    }
    print_r($data);?>$siteuniqueid此参数已经没有了,而且你的C::t('portal_category')->fetch(1);返回的数组,就是用$data存放的,所以你的while是没有用的若想获取表中全部数据,就用DB类操作吧,因为discuz封装的表模型中(portal_category这个表)是没有获取全部数据的方法
    DB::fetch_all('SELECT * FROM %t',array('portal_category'));