刚刚在写代码的时候,遇到一个奇怪的问题。
我想在图片上传成功后,向表uploads中插入一条记录。
那么问题来了,我新了一个insertuploadtbl函数
function insertuploadtbl($sfilename,$sfullurl,$mediatype){ global $dsql; echo '222xx--'; require_once(dirname(__file__)./../../../../../common.inc.php); require_once(dirname(__file__)./../../../../../userlogin.class.php); echo '333xx--'; //检验用户登录状态 $cuserlogin = new userlogin(); $nowtme = time(); $fsize = filesize($sfullurl); $inquery = insert into `#@__uploads`(arcid,title,url,mediatype,width,height,playtime,filesize,uptime,mid) values ('0','$sfilename','$sfullurl','$mediatype','0','0','0','{$fsize}','{$nowtme}','.$cuserlogin->getuserid().'); ; echo $inquery; $dsql->executenonequery($inquery); $fid = $dsql->getlastid(); addmyaddon($fid, $sfullurl); }
代码可以执行,我用ff调试得到如下结果:
查了查表,里面并没有新增记录。
可是我把函数里的这段代码,放在函数的外面执行,却是成功的,表里新增了一条记录。
想问问大家,是否在函数里面,global $dsql;是不起作用的,有什么办法能够在函数里面
成功执行sql语句。在这先谢谢了,搞了好几个小时,都没弄明白。
回复讨论(解决方案) 函数里包含文件不可以的吧
可以呀。。详见dedecms中的 include\enums.func.php 中有。。比如
/** * 获取数据的js代码(二级联动) * * @access public * @param string $egroup 联动组 * @return string */function getenumsjs($egroup){ global ${'em_'.$egroup.'s'}; include_once(dededata.'/enums/'.$egroup.'.php'); $jscode = ; return $jscode;}
现在感觉不是include_one的问题,如果这个有问题的话,
$cuserlogin->getuserid(); 就会不对了。所以我感觉应当还是global $dsql; 没作用。
导致$dsql->executenonequery($inquery); 没执行插表操作。请求大家的指点。
有人知道么,求指教。。
我这边没有织梦 你可以写一条查询语句试试,global $dsql;有用没用
问题解决了,原因就是不能放在函数里面。把代码拿出来就行了。