欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  后端开发

这样建入口文件哪里错了呢

程序员文章站 2022-06-08 11:46:12
...
我在discuz根目录下建了一个名为test.php的文件,主要是仿制forum.php这个文件里面的内容,有些删了,代码如下
fetch('catname');while($value=DB::fetch($siteuniqueid)){	$data[]=$value;	}print_r($data);echo $data[0];?>

建这个文件的目录是做测试用的,比如有一个表portal_category,里面有一个字段catname,我想用这个新建文件做试验,打印出catname字值下的所有的值,但是在地址栏中输入http://localhost/test.php 后,结果是空白,但不报错,不知为啥


回复讨论(解决方案)

本人也是个菜鸟,最开始遇到过变白的原因变量没加 $,后来是函数声明的那个文件没有引进来。。

自己在认为可能有错的地方 echo "" 一些东西,看看具体是哪错了,慢慢试把。。

本人也是个菜鸟,最开始遇到过变白的原因变量没加 $,后来是函数声明的那个文件没有引进来。。

自己在认为可能有错的地方 echo "" 一些东西,看看具体是哪错了,慢慢试把。。


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

建discuz的入口文件,只需要如下两句

require_once './source/class/class_core.php';C::app()->init();

你没有C::app()->init();


本人也是个菜鸟,最开始遇到过变白的原因变量没加 $,后来是函数声明的那个文件没有引进来。。

自己在认为可能有错的地方 echo "" 一些东西,看看具体是哪错了,慢慢试把。。


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


sorry

建discuz的入口文件,只需要如下两句

require_once './source/class/class_core.php';C::app()->init();

你没有C::app()->init();
init();$siteuniqueid = C::t('portal_category')->fetch('catname');while($value=DB::fetch($siteuniqueid)){	$data[]=$value;	}print_r($data);?>

我这样加上了,还是打印不出来,空白,没有提示报错

$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);

$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);


这回行了,下面是正确的代码,还有一点有疑惑:你说 实际上只有用DB::query查询的语句,返回的才是资源类型
但是我的代码中没有去掉DB::query为啥还能正确打印呢
init();$data = C::t('portal_category')->fetch(1);while($value=DB::fetch($siteuniqueid)){	$data[]=$value;	}print_r($data);?>

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


$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);


这回行了,下面是正确的代码,还有一点有疑惑:你说 实际上只有用DB::query查询的语句,返回的才是资源类型
但是我的代码中没有去掉DB::query为啥还能正确打印呢
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'));

确实是这样,真想再给你加分,下次吧,下次给的分更多