ホームページ > バックエンド開発 > PHPチュートリアル > [初心者の方に聞いてください] MySQL データベースへの PHP の書き込みに関する問題

[初心者の方に聞いてください] MySQL データベースへの PHP の書き込みに関する問題

WBOY
リリース: 2016-06-13 13:31:09
オリジナル
983 人が閲覧しました

[初心者へのアドバイス] PHP による MySQL データベースへの書き込みに関する問題
ここで、PHP 配列を使用して、1 から 33 までの 6 つの数値を組み合わせたデータを生成します。約 100 万個のデータが、データ .TXT ファイルに生成されます。は次のとおりです
[1,2,3,4,5,6]
[1,2,3,4,5,7]
[1,2,3,4,5,8 ]
[1,2,3,4,5,9]
[1,2,3,4,5,10]
[1,2,3,4,5,11]
[1,2,3,4,5,12]
[1,2,3,4,5,13]
[1,2,3,4,5,14]
[1,2 ,3,4,5,15]
[1,2,3,4,5,16]
[1,2,3,4,5,17]
[1 ,2,3 ,4,5,18]
....
このようなデータをデータベースに入れたいと思います。これで、データベース テーブル HMK が作成されました。構造体
"hmkid ","int(11)","NO","PRI","","auto_increment"
"l1","int(10) unsigned","NO","" ,"",""
"l2","int(10) unsigned","NO","","",""
"l3","int(10) unsigned","NO ",""," ",""
"l4","int(10) unsigned","NO","","",""
"l5","int(10) unsigned ","NO", "","",""
"l6","int(10) unsigned","NO","","",""
PHP を記述するにはどうすればよいですか?データを txt ドキュメントに保存するのではなく、データベースに直接書き込むプログラムですか?
私の考え

PHP コード
<!--

Code highlighting produced by Actipro CodeHighlighter (freeware)
http://www.CodeHighlighter.com/

-->
$db=new mysqli("localhost","admin","admin","ssq");
$db->query("truncate table hmk");
$info = array(1, 2, 3,4,5,6);//$info是中间生成的的组合数组.
foreach ($info as $skey=>$value){
     //echo 'my array is underline:'.$key."=>".$value."</br>" ;
     $query="insert into hmk(l1,l2,l3,l4,l5,l6) values($values)";  
     $result=$db->query($query) ;
} 
if (result)
echo "good luck"           ;
else echo "sorry"    ;
$db->close();
ログイン後にコピー

質問 2: TXT ドキュメントをインポートするプログラムは何ですか?データベースに書き込みますか? L1 に最初のデータが保存され、L2 に 2 番目のデータが保存されます。

1 ~ 33 の結合データを生成するプログラムについては、を参照してください。
PHP コード
<!--

Code highlighting produced by Actipro CodeHighlighter (freeware)
http://www.CodeHighlighter.com/

-->
$a  = range(1, 33);
$ar = combination($a, 6);

//求组合高效率的10移动法
function combination($numArr,$combineLen) {
  $numCt    = count($numArr);
  if($combineLen > $numCt) return;
  $bin    = str_pad('',$combineLen,'1');
  $bin    = str_pad($bin,$numCt,'0',STR_PAD_RIGHT);    
  $find    = $bin;
  $rs[]    = implode(' ',array_slice($numArr,0,$combineLen));
  $j        = 1;
  while(strrev($find) != $bin) {
    $k = explode('10',$find,2);
    $find = $find{0} === '0' ? strrev($k[0]).'01'.$k[1] : $k[0].'01'.$k[1];
    for($i=0;$i<$numCt;$i++) $rs[$j] .=  $find[$i] ?  $numArr[$i] . " " : '';
    $j++;
  }
  return $rs;
}


ログイン後にコピー


-----解決策-------- -------------
PHP コード
$fp = fopen('data.txt', 'r');
while( !feof($fp) ){
    $line = トリム( fget($fp) );
    $sqlvalue .= '('.substr($line, 1, -1) . '),';
}
$sql = "hmk(l1,l2,l3,l4,l5,l6) 値に挿入";
$sql = $sql . substr($sqlvalue, -1, 1); // 末尾の , を削除します。

$db = new mysqli("localhost","admin","admin","ssq");
$result = $db->query($sql);
if( ! $result ){
    echo $db->e​​rror();
    var_dump($sql);
}
<br><font color="#e78608">------解決策---------</font><br>クエリごとに 1 つのレコードのみを挿入するのは非効率すぎます。はい、一度に 50,000 項目など、バッチで挿入できます: <br><br>
ログイン後にコピー
PHP コード
$data = array(array(1,2,3,4,5,6), array(1,2,3,4,57)); //まず、各要素が数値のセットであるデータ配列を生成します。の配列
$idx = 0;
while($idx query($sql);
    $idx += 50000;
}
$db->close();
<br><font color="#e78608">------解決策---------------------- <div class="clear"></div></font>
ログイン後にコピー
関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート