为了账号安全,请及时绑定邮箱和手机立即绑定

更新大型数据集

更新大型数据集

PHP
心有法竹 2022-08-05 09:53:44
我可以上传一个包含3000条记录的csv文件,但是当我尝试更新时,需要很长时间,这会导致请求超时错误。插入:$sqlInsert = "INSERT ignore into datanyc (`Symbol`,`Data_date`,`Open`,`High`,`Low`,`Last`,`Volume`)                values ('".$column0."','".$dataDate."','".$column[2]."','".$column[3]."',                '".$column[4]."','".$column[5]."','".$column[6]."')";                       更新语句:$date_query="SELECT max(Data_date) as Prev_date FROM datanyc WHERE Data_date < '$dataDate' ";$date_result=mysqli_query($con,$date_query);$fetch=mysqli_fetch_array($date_result);$Prevdate=$fetch['Prev_date'];$temp="SELECT Last as last, Symbol as symbol FROM datanyc WHERE Data_date = '$Prevdate'";$date1=mysqli_query($con,$temp);while($row=mysqli_fetch_array($date1)){    //array_push($symbol,$row['symbol']);    //array_push($last,$row['last']);    $qry="UPDATE datanyc SET Prevclose = '".$row['last']."' WHERE Symbol LIKE '".$row['symbol']."' AND Data_date= $dateDate";    mysqli_query($con,$qry);    //$date=$row['max(Data_date)'];}
查看完整描述

1 回答

?
qq_笑_17

TA贡献1818条经验 获得超7个赞

首先,在和列上添加索引,SymbolData_date

其次,将更新查询更改为一个查询,这样您就不需要像这样循环更新:

$sql = "UPDATE
          datanyc AS a
        INNER JOIN datanyc b ON a.symbol = b.symbol
                     AND b.Data_date = '$Prevdate'
        SET a.Prevclose = b.last";$date1 = mysqli_query($con, $sql);


查看完整回答
反对 回复 2022-08-05
  • 1 回答
  • 0 关注
  • 144 浏览

添加回答

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号