0

以下のコードのクエリに問題はありません。しかし、2番目のコードはエラーをスローしています

SQL 構文にエラーがあります。1 行目の near '' を使用する正しい構文については、MySQL サーバーのバージョンに対応するマニュアルを確認してください。

作業コード:

<?php
mysql_connect("localhost", "","") or die(mysql_error());
mysql_select_db("") or die(mysql_error());

$result ="  CREATE TABLE google_csv(
    ÿþName varchar(80),
    Given_Name varchar(80),
    Additional_Name varchar(80),
    Family_Name varchar(80),
    Yomi_Name varchar(80),
    Given_Name_Yomi varchar(80),
    Additional_Name_Yomi varchar(80),
    Family_Name_Yomi varchar(80),
    Name_Prefix varchar(80),
    Name_Suffix varchar(80),
    Initials varchar(80),
    Nickname varchar(80),
    Short_Name varchar(80),
    Maiden_Name varchar(80),
    Birthday varchar(80),
    Gender varchar(80),
    Location varchar(80),
    Billing_Information varchar(80),
    Directory_Server varchar(80),
    Mileage varchar(80),
    Occupation varchar(80),
    Hobby varchar(80),
    Sensitivity varchar(80),
    Priority varchar(80),
    Subject varchar(80),
    Notes varchar(80),
    Group_Membership varchar(80),
    E_mail_1___Type int(11),
    E_mail_1___Value int(11),
    E_mail_2___Type int(11),
    E_mail_2___Value int(11),
    Phone_1___Type int(11),
    Phone_1___Value int(11),
    Phone_2___Type int(11),
    Phone_2___Value int(11),
    Phone_3___Type int(11),
    Phone_3___Value int(11),
    Address_1___Type int(11),
    Address_1___Formatted int(11),
    Address_1___Street int(11),
    Address_1___City int(11),
    Address_1___PO_Box int(11),
    Address_1___Region int(11),
    Address_1___Postal_Code int(11),
    Address_1___Country int(11),
    Address_1___Extended_Address int(11),
    Website_1___Type int(11),
    Website_1___Value int(11)
)";

echo $result;

mysql_query($result);
echo mysql_error();
?>

コード生成エラー。

<?php

// GENERATE TABLE FROM FIRST LINE OF CSV FILE

$inputFile = 'google.csv';
$tableName = 'google_csv';

$fh = fopen($inputFile, 'r');
$contents = fread($fh, 5120); // 5KB
fclose($fh);

$fileLines = explode("\n", $contents);

$fieldList = explode(',', $fileLines[0]);

$lastField=count($fieldList)-1;

echo "Total Fields :".count($fieldList)."<br>";

echo "Last Field :".$lastField."<br>";

$result ="CREATE TABLE $tableName(";

for($i = 0; $i < count($fieldList); $i++)
{
    if(preg_match('/[1-9]/', $fieldList[$i]))
    {

    if ($i==$lastField)
    {$result .=str_replace(array(" ",'-'),"_",$fieldList[$i]). ' int(11)';}
    else
    {$result .=str_replace(array(" ",'-'),"_",$fieldList[$i]). ' int(11),';}

    }
    else
    {

    if($i==$lastField)

    {$result .=str_replace(array(" ",'-'),"_",$fieldList[$i]). ' varchar(80)';}
    else
    {$result .=str_replace(array(" ",'-'),"_",$fieldList[$i]). ' varchar(80),';}

    }
}

$result .=")";

if ($result) {echo $result."<br>".$i."<br>";} else {Echo "Some Problem!";}

mysql_connect("localhost", "","") or die(mysql_error());
mysql_select_db("") or die(mysql_error());

mysql_query($result);

echo mysql_error();

?>

ここからの出力を最初のコードで使用してい$resultますが、完全に正常に動作します! 2 番目のコードのどこが間違っていますか?

$result エコーが与える

CREATE TABLE google_csv(ÿþName varchar(80),Given_Name varchar(80),Additional_Name varchar(80),Family_Name varchar(80),Yomi_Name varchar(80),Given_Name_Yomi varchar(80),Additional_Name_Yomi varchar(80),Family_Name_Yomi varchar(80 ),Name_Prefix varchar(80),Name_Suffix varchar(80),Initials varchar(80),Nickname varchar(80),Short_Name varchar(80),Maiden_Name varchar(80),Birthday varchar(80),Gender varchar(80), Location varchar(80),Billing_Information varchar(80),Directory_Server varchar(80),Mileage varchar(80),Occupation varchar(80),Hobby varchar(80),Sensitivity varchar(80),Priority varchar(80),Subject varchar (80),Notes varchar(80),Group_Membership varchar(80),E_mail_1_ Type int(11),E_mail_1 _Value int(11),E_mail_2_ Type int(11),E_mail_2 _Value int(11),Phone_1_ Type int(11) ,電話_1_Value int(11),Phone_2_ Type int(11),Phone_2 _Value int(11),Phone_3_ Type int(11),Phone_3 _Value int(11),Address_1_ Type int(11),Address_1 _Formatted int(11),Address_1_番地int(11),Address_1_City int(11),Address_1_PO_Box int(11),Address_1_Region int(11),Address_1_Postal_Code int(11),Address_1_Country int(11),Address_1_Extended_Address int(11), Website_1_Type int (11),Website_1___Value int(11))

ここではすべて問題ないようです。しかしその後......

4

1 に答える 1

0

これは何ですか :

ÿþ

$result ="CREATE TABLE google_csv(ÿþName ....")

           -----------------------^

ÿþ は特殊文字 (0xFE、0xFF) です。OPが列名でそれらを望んでいるとは思わない、もしそうなら、それはで囲まれるべきです

`ÿþName`

http://en.wikipedia.org/wiki/ISO_8859-1

于 2012-09-10T14:26:00.950 に答える