首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何使用php mysql加载数据INFILE将每个记录的变量值增加1

如何使用php mysql加载数据INFILE将每个记录的变量值增加1
EN

Stack Overflow用户
提问于 2016-05-04 19:05:31
回答 2查看 630关注 0票数 0

我试图使用LOAD方法(csv数据到数据库)为其中一个列保存一个递增值。我所尝试的一切都不起作用。没有额外的serial_no字段,一切都会很好地导入,如果我将硬编码值设置为serial_no,这也是可行的。只是不能让它将每个记录的数值增加1。

--

代码语言:javascript
复制
$loadsqlfiletodb = "SET @a:=".$serial_no_max_new.";
        LOAD DATA LOCAL INFILE '".$target_file."'
        INTO TABLE ".DB_NAME2.".list_data
        FIELDS TERMINATED BY ','
        OPTIONALLY ENCLOSED BY '\"' 
        LINES TERMINATED BY '\n'
        IGNORE 1 LINES 
        (first,last,address,city,state,zip,company,tracking_number,vin,year,make,model,rough,average,clean,misc1,misc2,misc3,misc4,misc5,misc6,misc7,misc8,misc9,misc10,list,email,phone,image_name,image_path)
        SET cid = ".$campaignid.",
            jid = ".$jobid.",
            serial_no = @a:=@a+1 ";

        mysql_query($loadsqlfiletodb) or die(mysql_error());

--

代码语言:javascript
复制
$loadsqlfiletodb = "
        SET @a:='".$serial_no_max_new."'
        LOAD DATA LOCAL INFILE '".$target_file."'
        INTO TABLE ".DB_NAME2.".list_data
        FIELDS TERMINATED BY ','
        OPTIONALLY ENCLOSED BY '\"' 
        LINES TERMINATED BY '\n'
        IGNORE 1 LINES 
        (first,last,address,city,state,zip,company,tracking_number,vin,year,make,model,rough,average,clean,misc1,misc2,misc3,misc4,misc5,misc6,misc7,misc8,misc9,misc10,list,email,phone,image_name,image_path)
        SET cid = ".$campaignid.",
            jid = ".$jobid.",
            serial_no = @a:=@a+1 ";

        mysql_query($loadsqlfiletodb) or die(mysql_error());

--

代码语言:javascript
复制
$loadsqlfiletodb = "LOAD DATA LOCAL INFILE '".$target_file."'
        INTO TABLE ".DB_NAME2.".list_data
        FIELDS TERMINATED BY ','
        OPTIONALLY ENCLOSED BY '\"' 
        LINES TERMINATED BY '\n'
        IGNORE 1 LINES 
        (first,last,address,city,state,zip,company,tracking_number,vin,year,make,model,rough,average,clean,misc1,misc2,misc3,misc4,misc5,misc6,misc7,misc8,misc9,misc10,list,email,phone,image_name,image_path)
        SET cid = ".$campaignid.",
            jid = ".$jobid.",
            serial_no = ".$serial_no_max_new."+1 ";

        mysql_query($loadsqlfiletodb) or die(mysql_error());

--

代码语言:javascript
复制
$loadsqlfiletodb = "LOAD DATA LOCAL INFILE '".$target_file."'
        INTO TABLE ".DB_NAME2.".list_data
        FIELDS TERMINATED BY ','
        OPTIONALLY ENCLOSED BY '\"' 
        LINES TERMINATED BY '\n'
        IGNORE 1 LINES 
        (first,last,address,city,state,zip,company,tracking_number,vin,year,make,model,rough,average,clean,misc1,misc2,misc3,misc4,misc5,misc6,misc7,misc8,misc9,misc10,list,email,phone,image_name,image_path)
        SET cid = ".$campaignid.",
            jid = ".$jobid.",
            serial_no = ".$serial_no_max_new." = ".$serial_no_max_new."+1 ";

        mysql_query($loadsqlfiletodb) or die(mysql_error());

最新情况:

这是整件事。序列号总是9位数。不多也不差。当序列达到999999999时,下一个记录的序列将是000000000。但是,不要担心九到零部分。此时,我正在尝试使用将文件导入数据库的方法,将该列的值增加1。

代码语言:javascript
复制
$query_max = mysql_fetch_array(mysql_query("SELECT id, latest_serial_no FROM ".DB_NAME2.".latest_serial_number WHERE id=1"), MYSQL_ASSOC);
        $serial_no_max = $query_max["latest_serial_no"];
        $serial_no_max_new = $serial_no_max;
        if ($serial_no_max > 999999998) {$serial_no_max_new = 000000000;}

        $padd = "";
        $serial_len = strlen($serial_no_max_new);
        if($serial_len < 9) {
            $serial_len = (9 - $serial_len);
            for($is=0;$is<$serial_len;$is++) {
                $padd .= "0";
            }
            $serial_no_max_new = $padd . $serial_no_max_new;
        }
        $query_serial = trim($serial_no_max_new);
        //echo "q_s: ".$query_serial;

        //Import uploaded file to Database
        //$target_file is where the uploaded file is located

        $loadsqlfiletodb = "SET @a:=".$query_serial.";
        LOAD DATA LOCAL INFILE '".$target_file."'
        INTO TABLE ".DB_NAME2.".list_data
        FIELDS TERMINATED BY ','
        OPTIONALLY ENCLOSED BY '\"' 
        LINES TERMINATED BY '\n'
        IGNORE 1 LINES 
        (first,last,address,city,state,zip,company,tracking_number,vin,year,make,model,rough,average,clean,misc1,misc2,misc3,misc4,misc5,misc6,misc7,misc8,misc9,misc10,list,email,phone,image_name,image_path)
        SET cid = ".$campaignid.",
            jid = ".$jobid.",
            serial_no = @a:=@a+1 ";

        mysql_query($loadsqlfiletodb) or die(mysql_error());
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2016-05-04 20:02:35

也许是这样的:

代码语言:javascript
复制
 /*1 get last serial number.

 open csv file.
 foreach row in csv file:
    increment serial number.
    if max number
       set serial number to 0.
    add new field to csv row

 close csv file

 insert csv to database*/


    $query_max = mysql_fetch_array(mysql_query("SELECT id, latest_serial_no FROM ".DB_NAME2.".latest_serial_number WHERE id=1"), MYSQL_ASSOC);
    $serial_no_max = $query_max["latest_serial_no"];
    $serial_no_max_new = $serial_no_max;
    if ($serial_no_max > 999999998) {$serial_no_max_new = 000000000;}

    $padd = "";
    $serial_len = strlen($serial_no_max_new);
    if($serial_len < 9) {
        $serial_len = (9 - $serial_len);
        for($is=0;$is<$serial_len;$is++) {
            $padd .= "0";
        }
        $serial_no_max_new = $padd . $serial_no_max_new;
    }
    $query_serial = trim($serial_no_max_new);
    //echo "q_s: ".$query_serial;

    // Add serail number to csv code
    $csv = fopen($target_file, "r");
    $tmp_csv_addr = $target_file . "2";
    $tmp_csv = fopen($tmp_csv_addr, "a");
    while (($data = fgetcsv($csv, 0, ",")) !== FALSE) {
        $data[] = $query_serial;
        fputcsv($tmp_csv, $data, ",");
    }
    fclose($csv);
    fclose($tmp_csv);

    // Insert into database
    $loadsqlfiletodb = "LOAD DATA LOCAL INFILE '".$tmp_csv_addr."'
    INTO TABLE ".DB_NAME2.".list_data
    FIELDS TERMINATED BY ','
    OPTIONALLY ENCLOSED BY '\"' 
    LINES TERMINATED BY '\n'
    IGNORE 1 LINES 
    (first,last,address,city,state,zip,company,tracking_number,vin,year,make,model,rough,average,clean,misc1,misc2,misc3,misc4,misc5,misc6,misc7,misc8,misc9,misc10,list,email,phone,image_name,image_path,serial_no)
    SET cid = ".$campaignid.",
        jid = ".$jobid;

    mysql_query($loadsqlfiletodb) or die(mysql_error());

    unlink($tmp_csv);
票数 1
EN

Stack Overflow用户

发布于 2016-05-04 19:43:05

使用auto_incement列(id)将数据加载到表中。

然后运行一个更新:

代码语言:javascript
复制
UPDATE list_data
SET serail_no = MOD(id, 1000000000)
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/37035983

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档