我有一个数据导入例程,它接受 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);
提前感谢您的帮助!