快上网专注成都网站设计 成都网站制作 成都网站建设
成都网站建设公司服务热线:028-86922220

网站建设知识

十年网站开发经验 + 多家企业客户 + 靠谱的建站团队

量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决

php数据库转圈 php跳转语句

php 数据库循环取值问题

$query4="select count(name) as renshu from yxh_huiyi_qd where huiyi_id=$HUIYI_ID and city=$TONGJI_CITY

交口网站建设公司创新互联,交口网站设计制作,有大型网站制作公司丰富经验。已为交口1000+提供企业网站建设服务。企业网站搭建\成都外贸网站建设要多少钱,请找那个售后服务好的交口做网站的公司定做!

这句sql语句把变量用引号括起来,因为city的类型应该是varchar(或char)型的,不加引号的话会认为是数值型的(只有数值型的不需要加引号)

另外,由于PHP单双引号的不同作用,建议你用连字符连接:

$query4="select count(name) as renshu from yxh_huiyi_qd where huiyi_id=".$HUIYI_ID." and city = '".$TONGJI_CITY."'";

这样也以防没有正确识别变量

PHP新手问题,关于AppServ的基本使用(apache和mysql的问题),谢谢!

给你xampp的本地搭建的视频,安装视频一步步走就可以了。

appserv我没有用过,本人一直用xampp作为本地运行环境。

php数据多影响返回速度吗

框架用的是ci,数据库是sqlsrv(sql server 2008),sql查询返回的结果集有2万条数据,我在ci框架里面执行这个sql语句,网页一直在转圈,2万条数据要转30秒左右,但是我的sql语句在sql server 2008 R2 里面执行 是秒查,在ci里面用自带查询sql执行时间是200毫秒,,说明我的语句并不慢。个人觉得应该是返回数据太多导致慢的,返回的是2万条数据,20个字段左右,,因为我做的是统计 ,要把数据导出成csv文件,所以数据比较多,这个该怎么处理?

我的sql 语句是select * from table where create_time between 'xxxx-xx-xx 00:00:00' and 'xxxx-xx-xx 23:59:59'; 是根据时间段来的 如果用户选择的时间范围小 那数据就少 如果范围大 那数据就大 数据大的时候就很慢

public function aa(){

$sql ="select * from table where create_time between 'xxxx-xx-xx 00:00:00' and 'xxxx-xx-xx 23:59:59'";

$result=$this-db-query($sql)-result_array();

}

这已经是最简单的查询了,sql语句秒查,但是用浏览器执行就很慢,

我在浏览器里面执行 , 如果查询结果几万条的话 浏览器就一直转圈,要等四十多秒,500条足有数据是3、4秒

我在想是不是result_array()这一步 需要循环需要花费太多的时间,本身记录就有几万条,然后还有二十个字段

==============2017-05-16 16:01更新===============

我没有用ci框架自带的result_array() ,查看ci框架文档的时候看到一段话:

经常的,你会需要提供一个数据库的 connection ID 或是一个 result ID, connection ID 可以这样来

$this-db-conn_id;

result ID 可以从查询返回的结果对象获取,像这样:

$query = $this-db-query("SOME QUERY");

$query-result_id;

于是我修改了我的代码 拿 result_id 去循环读取每条记录

$sql ="select xxx";

$query=$this-db-query($sql);

//这里因为我用的是sqlsrv 所以使用的是sqlsrv_fetch_array 来循环读取每一行

//然后每读一行 就写如csv文件

while($row=sqlsrv_fetch_array($query-result_id,SQLSRV_FETCH_ASSOC)){

//这里是把row 写入csv文件的代码

}

具体的代码就是下面了

$sql="xxx";

$query=$this-db-query($sql);

$filename= "CostDetail.csv";//导出的文件名

header('Content-Type: application/vnd.ms-excel');

header('Content-Disposition: attachment;filename="'.$filename.'"');

header('Cache-Control: max-age=0');

// 打开PHP文件句柄,php://output 表示直接输出到浏览器

$fp = fopen('php://output', 'a');

// 输出Excel列名信息

$head = array(xxx);

foreach ($head as $i = $v) {

// CSV的Excel支持GBK编码,一定要转换,否则乱码

$head[$i] = iconv('utf-8', 'gbk', $v);

}

// 将数据通过fputcsv写到文件句柄

fputcsv($fp, $head);

// 计数器

$cnt = 0;

// 从数据库中获取数据,为了节省内存,不要把数据一次性读到内存,从句柄中一行一行读即可

$limit = 5000;

while ($row=sqlsrv_fetch_array($query-result_id,SQLSRV_FETCH_ASSOC)){

$cnt ++;

if ($limit == $cnt) { //刷新一下输出buffer,防止由于数据过多造成问题

ob_flush();

flush();

$cnt = 0;

}

//这里是把每个字段的编码转成gbk

$newRow[] = $this-_mb_convert_encoding($row['edis_orgsoid']);

....

unset($row);

fputcsv($fp, $newRow);

unset($newRow);

}

exit;

这样能导出文件 但是我看了一下 19204行的,16列 的csv文件 3M左右 , 需要40-45秒的时间才能导出好,,我想问这时间还能优化的再快点吗

php连接数据库怎么显示一直在等待

如果连接成功了,不能插入数据,肯定是你最后一句写错了。

mysqli_query($db,"INSERT INTO tablename(username,userpass) VALUES('$name','$pass')");

有几种可能:

列名写对象没有?

values()里的值的格式写对了没有?引号有没有加到?

我看你写的:('$name','$pass')") 如果是变量的话,是不能加单引号的,这样是读到不变量值的。

php提交表单浏览器转圈

网络问题。php提交表单浏览器转圈是网络问题,表单具有默认的提交行为,默认是同步的,即同步表单提交,浏览器会锁死,等待服务端的响应结果。换个好一点的网络。

关于xmlhttprequest的问题

Cache-control";根据是否需要缓存,可以设置response.setHeader(");text/xml;charset=utf-8"。当返回xml文档时候Servlet一定要设置response.setContentType("

responseXML决定响应的数据类型xml文档用ajax请求时候:

响应的数据类型由ajax设置的接受数据方式决定:

responseText决定响应的数据类型是文本


分享名称:php数据库转圈 php跳转语句
文章链接:http://6mz.cn/article/dodheci.html

其他资讯