Jam*_*mes 2 mysql sql into-outfile
知道为什么这在MySQL 5.1中失败了:
SET @LOAD_TIME = UNIX_TIMESTAMP();
SET @OUTFILE = CONCAT(CONCAT('/tmp/outfile_', @LOAD_TIME), '.sql');
SELECT *
FROM `tableA`
INTO OUTFILE @OUTFILE;
Run Code Online (Sandbox Code Playgroud)
它是MySQL的SELECT的限制还是我在这里遗漏了什么?
你不能使用变量作为文件名.像LIMIT一样,它必须是文字值,而不是公式或变量.
例如,要写入此文件的文件名是什么?
SET @LOAD_TIME = UNIX_TIMESTAMP();
SET @OUTFILE = CONCAT(CONCAT('/tmp/outfile_', @LOAD_TIME), '.sql');
SELECT @OUTFILE = columnA
, columnB
FROM `tableA`
INTO OUTFILE @OUTFILE;
Run Code Online (Sandbox Code Playgroud)
这与LIMIT上的限制类似.如果在LIMIT子句中允许使用表达式,则可能会出现具有不可预测行为的查询.例如,假设您有一个包含10行的表,而a列的值为1到10.这个查询的输出是什么?
SELECT *
FROM myTable
ORDER
BY a
LIMIT 10 - a
Run Code Online (Sandbox Code Playgroud)
此限制的基础是:如果您可以计算限制,则应明确计算限制,然后使用文字值构建查询.允许表达式10 - a进行评估会使查询执行计划变得更加复杂.