0

implode ステートメントを使用して、この配列をデータベースに挿入しようとしています。しかし、どこが間違っているのかを見つけるのに苦労しています。基本的に、以下の2つの関数を変換して文字列を返すことを検討しています:

 function Titles($link) {
$str = file_get_contents($link);    
if( strlen( $str )>0 ) {    
    preg_match_all( "/\<title\>(.*)\<\/title\>/", $str, $titles );
    if (count($titles) > 1) {
        return $titles[1];   
    }
}

return '';
}

  function getMetas($link) {
$str1 = file_get_contents($link);    

if (strlen($str1)>0) {
    preg_match_all( '/<meta.*?name=("|\')description("|\').*?content=("|\')(.*?)("|\')/i', $str1, $description);
    if (count($description) > 1) {
        return $description[4];   
    }

}


 }


  $data = array();
  foreach ($links as $link) {
$output = array(
    "title"       => Titles($link), 
  "link"        => $link,
  "description" => getMetas($link),
  "keywords" => getKeywords($link) 
   );
   if (empty($output["description"])) 
   {$output["description"] = getWord($link);
  }
   $data[] = $output;
  }
  print_r($data);  

  mysql_query("INSERT INTO scan (title, url, description, keywords) VALUES ('".implode("'),('",$data)."')");

  if (!mysql_query()) {
echo "woops";
    }

   mysql_close($connect);
4

2 に答える 2

1

問題は、それ$dataが多次元配列であるため、内破した後も、クエリに文字列ではなく配列が残っていることです。

implode以前に$outputも使用することでそれを解決できます。

$data[] = implode(',', $output);

それとは別にmysql_real_escape_string、元の変数で使用する必要がありますが、mysql_*関数が非推奨になっているため、mysqli または PDO の準備済みステートメントに切り替える必要があります。

編集:実際には、両方の内破を変更する必要があります:

 $data[] = '"' . implode('","', $output) . '"';
 ...
 mysql_query( "INSERT INTO scan (title, url, description, keywords)
    VALUES (" . implode('),(',$data) . ")" );
于 2012-09-26T17:12:37.060 に答える
0

これを試して

$fields =   array_keys($data);
    $values =   array_values($data);

    $formatedValues =   array();
    foreach($values as $val)
    {   $val    =   "'".addslashes($val)."'";
        $formatedValues[]   =   $val;
    }
      $table="scan";

$sql    =   "INSERT INTO ".$table." (";
    $sql    .=  implode(", ",$fields).") ";
    $sql    .=  "VALUES( ";
    $sql    .=  implode(", ",$formatedValues);
    $sql    .=  ")";
    mysql_query($sql) or die(mysql_error());
于 2012-09-26T17:43:43.973 に答える