MySql服务器已经消失 - PHP

时间:2015-07-20 07:21:48

标签: php sql web-services web-crawler

我是抓取网页内容的初学者。我试图从另一个网站检索内容。所以编写了爬虫代码。成功抓取其他网页上的内容。我试图存储来自其他网站的所有数据。

我得到了#34; MySql Server已经消失了#34;错误。任何人都可以帮我找出我的错误吗?

Connection.php:

<?php
$hostname_TestConnection = "******";
$database_TestConnection = "*******";
$username_TestConnection = "*******";
$password_TestConnection = "********";
$TestConnection = mysqli_connect($hostname_TestConnection, $username_TestConnection, $password_TestConnection) or trigger_error(mysqli_error($TestConnection),E_USER_ERROR); 
?>

的index.php:

<?php require_once('Connections/TestConnection.php');
include_once('simple_html_dom.php');  

ini_set('mysql.connect_timeout', -1);
ini_set('default_socket_timeout', -1);

if (!function_exists("GetSQLValueString")) {
 function GetSQLValueString($theValue, $theType,  $TestConnection, $theDefinedValue = "", $theNotDefinedValue = "") 
{
  if (PHP_VERSION < 6) {
  $theValue = get_magic_quotes_gpc() ? stripslashes($theValue) : $theValue;
}

$theValue = function_exists("mysql_real_escape_string") ?  mysqli_real_escape_string($TestConnection, $theValue) :  mysqli_escape_string($TestConnection, $theValue);

switch ($theType) {
 case "text":
   $theValue = ($theValue != "") ? "'" . $theValue . "'" : "NULL";
   break;    
 case "long":
 case "int":
   $theValue = ($theValue != "") ? intval($theValue) : "NULL";
   break;
 case "double":
   $theValue = ($theValue != "") ? doubleval($theValue) : "NULL";
   break;
 case "date":
   $theValue = ($theValue != "") ? "'" . $theValue . "'" : "NULL";
   break;
 case "defined":
   $theValue = ($theValue != "") ? $theDefinedValue : $theNotDefinedValue;
   break;
 }
 return $theValue;
 }
}

$target_url = "***";
$html = new simple_html_dom();
$html_sub_page = new simple_html_dom();
$html->load_file($target_url);

//Declare elements {......}

//Retrieve latest ID from table {....}

//Main Page content {....}

//Sub Page content {....}

//Insert Into DB

if($flag == 1)
{
    for($i = 0 ; $i < $counter ; $i++)
    {

    $latestid ++;
    $guid .= $latestid;
    $post_name = $latestid.$post_name;

    $insertSQL = sprintf("INSERT INTO test_posts (post_author, post_date, post_date_gmt, post_content, post_title, post_excerpt, post_status, comment_status, ping_status, post_password, post_name, to_ping, pinged, post_modified, post_modified_gmt, post_content_filtered, post_parent, guid, menu_order, post_type,post_mine_type, comment_count) VALUES (%s, %s, %s, %s, %s, %s, %s, %s, %s, %s, %s, %s, %s, %s, %s, %s, %s, %s, %s, %s, %s, %s)",
                       GetSQLValueString($post_author, "int", $TestConnection),
                       GetSQLValueString($post_date, "date", $TestConnection),
                       GetSQLValueString($post_date_gmt, "date", $TestConnection),
                       GetSQLValueString($post_title_array[$i], "text", $TestConnection),
                       GetSQLValueString($post_title_array[$i], "text", $TestConnection),
                       GetSQLValueString($post_excerpt, "text", $TestConnection),
                       GetSQLValueString($post_status, "text", $TestConnection),
                       GetSQLValueString($comment_status, "text", $TestConnection),
                       GetSQLValueString($ping_status, "text", $TestConnection),
                       GetSQLValueString($post_password, "text", $TestConnection),
                       GetSQLValueString($post_name, "text", $TestConnection),
                       GetSQLValueString($to_ping, "text", $TestConnection),
                       GetSQLValueString($pinged, "text", $TestConnection),
                       GetSQLValueString($post_modified, "date", $TestConnection),
                       GetSQLValueString($post_modified_gmt, "date", $TestConnection),
                       GetSQLValueString($post_content_filtered, "text", $TestConnection),
                       GetSQLValueString($post_parent, "int", $TestConnection),
                       GetSQLValueString($guid, "text", $TestConnection),
                       GetSQLValueString($menu_order, "int", $TestConnection),
                       GetSQLValueString($post_type, "text", $TestConnection),
                       GetSQLValueString($post_mine_type, "text", $TestConnection),
                       GetSQLValueString($comment_count, "int", $TestConnection));

  mysqli_select_db($TestConnection,$database_TestConnection);
  $Result1 = mysqli_query($TestConnection, $insertSQL) or die(mysqli_error($TestConnection));

  $post_name = "-revision-v1"; 
  $guid = '****';
  echo "<br>Data ". ($i+1) . "succssfully inserted Into DataBase";
  //sleep(3);
 }
}

mysqli_free_result($RetrieveLatestID);
mysqli_close($TestConnection);
?>

1 个答案:

答案 0 :(得分:0)

为什么要从mysqli_切换到mysql_以获取错误消息?坚持mysqli_。虽然mysqli_error()需要db句柄作为第一个参数,但是你不能在你拥有的内容中使用它。请改用mysqli_connect_error(),因为这不需要db句柄。

为什么要检查mysql_real...函数是否存在,然后使用mysqli_real..函数..?