ほとんど10000個のレコードを挿入または更新します。 forループに挿入するには時間がかかります。別の方法では値を挿入するだけですが、duplicate_keyエントリにはエラーが表示されます。MysqlはYii Frameworkを挿入して更新するのに長い時間がかかります
$var=0;
if($method == 1)
{
// $sql5 is the current way trying but shows error
$sql5='insert into stu_regnum_hall(hall_name,row,column,register_number,subject_code,exam_date,session,unique_key) values';
for ($i = 0; $i <=$arr_length; $i++)
{
for ($j = 1; $j <= 5; $j++)
{
for($k=0;$k<=4;$k++)
{
if(isset($show[$var+$k]))
{
if($k==0)
{
$hall_name=$arr1[$i];
$row=$j;
}
$column=$k+1;
$reg_num=$show[$var+$k];
$sub_code=$newArr12[$var+$k];
$unique_key=$reg_num.$date.$session;
//current way to insert This is taking too long time to store nearly 10000 records
Yii::$app->db->createCommand('insert into stu_regnum_hall(hall_name,row,column,register_number,subject_code,exam_date,session,unique_key) values ("'.$hall_name.'","'.$row.'","'.$column.'","'.$reg_num.'","'.$sub_code.'","'.$date.'","'.$session.'","'.$unique_key.'") ON DUPLICATE KEY UPDATE hall_name ="'.$hall_name.'",row="'.$row.'",column="'.$column.'",register_number="'.$reg_num.'",subject_code="'.$sub_code.'",exam_date="'.$date.'",session="'.$session.'",unique_key="'.$unique_key.'"')->query();
//concatenation of $sql5
$sql5.='("'.$hall_name.'","'.$row.'","'.$column.'","'.$reg_num.'","'.$sub_code.'","'.$date.'","'.$session.'","'.$unique_key.'") ON DUPLICATE KEY UPDATE hall_name= "'.$hall_name.'",row="'.$row.'",column="'.$column.'",register_number="'.$reg_num.'",subject_code="'.$sub_code.'",exam_date="'.$date.'",session="'.$session.'",unique_ key="'.$unique_key.'",';
}
else
{
break;
}
}
$var=$var+5;
}
}
$sql5.='("");';
// This is the required answer but getting error
Yii::$app->db->createCommand($sql5)->query();
}
$ sql5クエリは少しカスタム使用INSERT IGNORE
、REPLACE
またはON DUPLICATE KEY UPDATE
とYii2 batchInsert
を試してみてください。この
longにどのくらいですか? –
10000レコードで約5分。 insertクエリは毎回forループで実行されます。その理由は –
です。自動化されたデータで満たしているので、仕事のスピードの1つになることは問題ではありません。 –