0

我有一个数据导入例程,它接受 CSV 文件,其中第一列包含一个字符数据集,该数据集由格式为 0123、0517、1531 等的 ID 值组成。通常是 4 位数字,3 位数字前导零。

数据正在使用 varchar(255) 字段加载到表中,但是当我调用 LOAD DATA 命令时,它全部被导入而没有前导零。我在这里缺少什么吗?

db_query('CREATE TABLE feed_buildings (
  BLDGID varchar(255),
  BLDGNAME varchar(255),
  CITY varchar(255),
  STATE varchar(255),
  ZIPCODE varchar(255),
  LLRDID varchar(255),
  BLDGGLA varchar(255),
  ADDRESS1 varchar(255),
  ADDRESS2 varchar(255),
  NMBRUNIT varchar(255),
  MNGRID varchar(255),
  INACTIVE varchar(255),
  OCCGLA varchar(255) )', false, false);

在此示例中,当我运行以下命令时,丢失前导零的是 BLDGID 字段:

$loadfields = ' ( BLDGID, BLDGNAME, CITY, STATE, ZIPCODE, LLRDID, @ignore, BLDGGLA, @ignore, ADDRESS1, 
  ADDRESS2, @ignore, @ignore, NMBRUNIT, MNGRID, @ignore, @ignore, @ignore, @ignore, @ignore, 
  @ignore, @ignore, @ignore, @ignore, @ignore, @ignore, @ignore, @ignore, INACTIVE, @ignore, 
  @ignore, @ignore, @ignore, @ignore, @ignore, OCCGLA )';

$loadquery = 'LOAD DATA LOCAL INFILE \'' . $path . '\' INTO TABLE feed_buildings . ' FIELDS TERMINATED BY \',\' ENCLOSED BY \'"\' LINES TERMINATED BY \'\r\n\' IGNORE 1 LINES';
db_query_unprepared($loadquery . $loadfields);

提前感谢您的帮助!

4

1 回答 1

0

忽略-我不确定前几次是如何发生的,但最后几次是正确导入的。

于 2013-02-18T20:26:00.720 回答