通过PHP大量插入MySQL数据库会跳过名称

时间:2011-08-11 00:52:37

标签: php mysql

我目前正在制作跟踪程序,该程序可以同时跟踪数百名用户,但我遇到了一个有点恼人的问题。我让用户插入数据库的方式是通过html textarea,然后我将它们作为参数发送。 60个人中总共有7个人(也总是名称相同)插入到数据库中,但它没有插入正确的数据。我试图插入那些用户并且它做得很好,所以一次插入所有人会有问题吗?

以下是我正在使用的一些代码:
的index.html

<head>

    <title>Test</title>

</head>

<body>

    <form name="input" action="tracker.php" method="get">
        <textarea name="names" rows="20" cols="20"></textarea><br>
        <input type="submit" value="Submit" />
    </form>

</body>

tracker.php

$database = mysql_connect("mysql.alwaysdata.com", "stacktest", "stackoverflow");

if (!$database) {
    die('Could not connect to database: ' . mysql_error());
}

mysql_select_db("stacktest_1", $database);

mysql_query("CREATE TABLE stats (username varchar(12), start text, UNIQUE (username))");

$names = explode("\n", $_GET['names']);

if (isset($_GET['track'])) {
    for ($i = 0; $i < count($names); $i++) {
        startTracker($names[$i]);
    }
}

displayData();

function startTracker($username) {
    $stats = getStats($username);
    mysql_query("INSERT IGNORE INTO stats (username, start) VALUES ('" . trim($username) . "', '$stats')");
}

function grabStats($username) {
    $query = mysql_query("SELECT * FROM stats WHERE username LIKE '$username'");
    while ($row = mysql_fetch_array($query)) {
        return $row['start'];
    }
}

function displayData() {
    global $names;
    for ($i = 0; $i < count($names); $i++) {
        $stats = getStats($names[$i]);
        $starting = getStat(grabStats($names[$i]), 2, 0);
        $current = getStat($stats, 2, 0);
        $gained = $currentExperience - $startingExperience;
        echo "Stats for <b>" . $names[$i] . "</b>:<br>";
        echo "Starting experience: " . number_format($starting) . "<br>";
        echo "Current experience: " . number_format($current) . "<br>";
        echo "Gained experience: " . number_format($gained) . "<br><br>";
    }
}

function getStats($username) {
    $curl = curl_init("http://hiscore.runescape.com/index_lite.ws?player=" . $username);
    curl_setopt ($curl, CURLOPT_CONNECTTIMEOUT, $timeout);
    curl_setopt ($curl, CURLOPT_USERAGENT, sprintf("Mozilla/%d.0", rand(4, 5)));
    curl_setopt ($curl, CURLOPT_HEADER, (int) $header);
    curl_setopt ($curl, CURLOPT_RETURNTRANSFER, 1);
    curl_setopt ($curl, CURLOPT_SSL_VERIFYPEER, 0);
    curl_setopt ($curl, CURLOPT_VERBOSE, 1);
    $httpCode = curl_getinfo($curl, CURLINFO_HTTP_CODE);
    $output = curl_exec($curl);
    curl_close ($curl);
    if (strstr($output, "<html><head><title>")) {
        return false;
    }
    return $output;
}

function getStat($stats, $row, $skill) {
    $stats = explode("\n", $stats);
    $levels = explode(",", $stats[$skill]);
    return $levels[$row];
}

mysql_close($database);

您会注意到数据库中 funkymunky11 没有数据,但我从该网站上清楚地看到了数据as you can see

我还创建了一个数据库,这样你就可以看到发生了什么: http://phpmyadmin.alwaysdata.com/

用户名:stacktest
密码:stackoverflow

以下是我用来测试的名字(我把它放在文本区域内):

  

aeterna
  quuxx
  funkymunky11
  ts danne

如果有一些不需要的代码,我很抱歉,我经历了几乎所有我认为不需要的东西。

提前致谢, 罗恩

1 个答案:

答案 0 :(得分:1)

我认为您需要查看insert命令中出现的错误。将以下代码复制到tracker.php页面,然后将调用更改为startTracker,以便调用startTrackerDebug。然后看看你得到了什么。请注意,在我的函数中,我使用sprintf()和mysql_real_escape_string()来确保插入时数据与mysql一致。

  function startTrackerDebug($username) {
    $stats = getStats($username);
    $query = sprintf("INSERT INTO stats (username, start) VALUES('%s', '%s')", 
                      mysql_real_escape_string(trim($username)), 
                      mysql_real_escape_string($stats));
    $result = mysql_query($query);
    if(!$result) echo(mysql_error() . "Query = $query");
  }