我是PHP的新手,我的语法和原则并不是很好。 我有这样的代码:
function exportFromTransbase($table_name) {
//$odbc_query = "SELECT * FROM " . $table_name. " WHERE ((CDS_CTM subrange(248 cast integer) = 1) AND (CDS_LNG_ID = 16))";
$odbc_query = "SELECT * FROM " . $table_name. "";
$data = odbc_exec($this->odbc_id, $odbc_query);
odbc_longreadlen($data, 10485760);
$oufile=fopen($table_name.".sql", 'w') or die("error writing file");
$q1='INSERT INTO `' . substr($table_name, 4) . '` VALUES';
fwrite($oufile, $q1);
while($row = odbc_fetch_array($data))
{
foreach($row as $key => $value) {
$keys[] = "`" . $key . "`";
if ($value == ""){
$value = 'NULL';
$values[] = "" . mysql_real_escape_string($value) . "";
}
else{
$values[] = "'" . mysql_real_escape_string($value) . "'";
}
//echo "\n \n ololo ".$value;
}
$mysql_query = "\n (".implode(",", $values).")," ;
fwrite($oufile, $mysql_query);
//mysql_query($mysql_query);
set_time_limit(0);
unset($keys);
unset($values);
unset($row);
}
$stat = fstat($oufile);
ftruncate($oufile, $stat['size']-1);
fseek($oufile, 0, SEEK_END);
fwrite($oufile, ";".$r);
//} while ($r < 5 );
fclose($oufile);
if ($mysql_query){
print "Ýêñïîðò äàííûõ èç òàáëèöû " . $table_name . " çàâåðøåí!";
//strtolower(substr($table_name, 4))
}
}
我需要自定义的内容,以便我导出除了一个之外的所有表字段,例如名为Size,我必须在db中插入此字段为空...
另外如果很容易,如何分批5000行分割我的SQL查询?所以插入(5000行)然后插入另一个5000 ....
但首先我需要导出所有字段,除了一个......
答案 0 :(得分:0)
据我所知,这是不可能的。
您可以简单地使用:
SELECT field1, field2, field3, field4 FROM table
请参阅Select all columns except one in MySQL?
如果您的table
中有更多字段,那么您只能使用*
。
在insert
时,您可以在condition
中制作ignores
field
new table
您不想要的{{1}}。
答案 1 :(得分:-1)
你能用吗
"select * from {table} where {sth} != {condition}"
然后您可以获取除一个以外的所有数据。根据您的情况切换一个。 同时,如果要插入5000,则可以一次读取5000行并插入。