0

我有一个令我困惑的问题,我无法将从 CSV 文件逐渐加载的字符串添加到写入数据库后的数组(通过 while 循环)。

代码运行,它反映了它已写入数据库的事实,但实际上没有发生任何事情,当我删除它写入数据库的字符串时就很好了。

语法应该是 $variable = 'string' 。$csv值;在这种情况下它不会写入数据库,但它会在以下情况下写入: $variable = $csvValue;

这是代码:

<?php
// Script to insert data from a CSV-file with AD information in it to a MySQL database.

// Connect to the database 
$connect = mysqli_connect("localhost","root","password","dbname"); 

if(!$connect){
   die('Could not <span id="IL_AD1" class="IL_AD">
    connect to</span> MySQL: ' . mysql_error());
}

// Charset
mysqli_query($connect, "SET NAMES 'utf8'");

// File path
define('CSV_PATH','/home/administrator/Desktop/'); 

$csvName = CSV_PATH . "AnsattInfo.csv"; // Name of CSV-file
$csvfile = fopen($csvName, 'r');
$theData = fgets($csvfile);
$i = 0;

while(!feof($csvfile)){

    $csv_data[] = fgets($csvfile, 2048);
    $csv_array = explode(",", $csv_data[$i]);
    $insert_csv = array();
    $insert_csv['sAMAccountName'] = $csv_array[0];
    $insert_csv['displayName'] = $csv_array[1];
    $insert_csv['employeeNumber'] = $csv_array[2];
    $insert_csv['mail'] = $csv_array[3];
    $insert_csv['company'] = $csv_array[4];
    $footer = str_replace(' ', '_', $insert_csv['company']);
    //$footer = '@' . str_replace(' ', '_', $insert_csv['company']);

    $query = "INSERT INTO playsms_tblUserTest (status, username, enable_webservices, webservices_ip, name, mobile, email, footer, country, datetime_timezone, language_module, fwd_to_mobile, send_as_unicode)
        VALUES(
            3,
            ".$insert_csv['sAMAccountName'].",
            1,
            '*.*.*.*',
            ".$insert_csv['displayName'].",
            ".$insert_csv['employeeNumber'].",
            ".$insert_csv['mail'].",
            ".$footer.",
            137,
            '+0100',
            'nb_NO',
            1,
            1         
    ) ON DUPLICATE KEY
        UPDATE name = $insert_csv[displayName], mobile = $insert_csv[employeeNumber], email = $insert_csv[mail], footer = $footer";

   mysqli_query($connect, $query);

   $i++;
}

fclose($csvfile);

echo "CSV successfully imported to User-table! \n";

mysqli_close($connect); // closing connection  
?>

我在这里真正想要做的是在 $footer 值的前面添加一个字符串,因为 @ 是联系人组的组名,其中 '@' 实际上是它是一个组的指示符。

在 CSV 文件中,公司名称前面没有“@”,这是我要添加的。像这样:

$footer = '@' . str_replace(' ', '_', $insert_csv['company']);

这不会产生任何语法错误,但实际上没有任何内容写入数据库。

有人对这里的解决方案有建议吗?

为任何帮助而欢呼。

4

1 回答 1

2

如果footer您的数据库中的字段是某种“字符串类型”,那么您还必须用字符串填充它:

/* ... */
            ".$insert_csv['employeeNumber'].",
            ".$insert_csv['mail'].",
            '".$footer."',
            137,
            '+0100',
            'nb_NO',
            1,
            1         
    ) ON DUPLICATE KEY
        UPDATE name = $insert_csv[displayName], mobile = $insert_csv[employeeNumber], email = $insert_csv[mail], footer = '$footer'";
/* ... */

并将其声明为 mysql-query 中的字符串,您必须将其放在引号之间,如上面所示的$footer值。

我认为您在查询中多次遇到相同的错误:例如$insert_csv['mail'],我猜也将是一个字符串。

提示:如果你使用了某种错误处理,那么你会看到有一些 mysql 错误(因为我正在使用pdo我真的不知道它是如何工作的mysqli)。

于 2015-06-19T06:53:16.483 回答