- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想使用mysqlsh
显式列出importTable
中LOAD DATA
的列
:
https://dev.mysql.com/doc/mysql-shell/8.0/en/mysql-shell-utilities-parallel-table.html
导入.js:
util.importTable("sample.csv", {schema: "myschema", table: "mytable",
showProgress: true, columns: ["id","firstname",@dummy,@dummy,"lastname"]});
我的 csv 包含 5 列。但是,如果我的最终表仅包含 id、名字、姓氏,我必须找到一种方法来跳过源 csv 的两列,
导入方式:
mysqlsh --user=root --password='rootpw' --socket=/var/run/mysqld/mysqld.sock < import.js
问题:语法错误:STDIN:2:347 处的标记无效或意外
。 @dummy
和 '@dummy'
和 "@dummy"
都不起作用。
问题:如何跳过虚拟列?当使用LOAD DATA
时,它可以在列选项中使用@dummy
。
最佳答案
从 MySQL Shell 8.0.22 开始,您可以通过用整数值替换 columns
选项中的列名称来跳过列。
util.importTable("/tmp/names.csv", {
table:"names",
columns: ["id", "firstname", 1, 2, "lastname"],
dialect: "csv-unix"
});
这相当于:
LOAD DATA LOCAL INFILE '/tmp/names.csv' INTO TABLE `names`
FIELDS TERMINATED BY ',' ENCLOSED BY '"' ESCAPED BY '\\'
LINES TERMINATED BY '\n'
(id, firstname, @1, @2, lastname);
自版本 8.0.22 起,MySQL Shell 的并行表导入实用程序 util.importTable() 具有新选项 decodeColumns
以及对 columns
选项的增强功能,使您能够到以与使用 LOAD DATA
语句相同的方式从导入文件中捕获列以进行输入预处理(或丢弃它们)。 decodeColumns
选项以与 LOAD DATA
语句的 SET
子句相同的方式指定捕获数据的预处理转换,并将它们分配给目标表中的列。
util.importTable
column
选项已扩展,现在接受整数作为数组值。作为第 k 个参数传递的整数值,捕获第 k 列在输入文件中作为名为 @i
的用户变量,其中 i
是传递的整数。
捕获的列值绑定(bind)到用户变量可以在decodeColumns
中使用在将结果分配给之前预处理和转换数据的选项表中的列。
示例 1 - 预处理列 2:
util.importTable('file.txt', {
table: 't1',
columns: ['column1', 1],
decodeColumns: {'column2': '@1 / 100'}
});
相当于:
LOAD DATA LOCAL INFILE 'file.txt'
INTO TABLE `t1` (column1, @var1)
SET `column2` = @var/100;
示例 2 - 跳过列:
util.importTable('file.txt', {
table: 't1',
columns: ['column1', 1, 'column2', 2, 'column3']
});
相当于:
LOAD DATA LOCAL INFILE 'file.txt'
INTO TABLE `t1` (column1, @1, column2, @2, column3);
示例 3 - 生成列值
util.importTable('file.txt', {
table: 't1',
columns: [1, 2],
decodeColumns: {
'a': '@1',
'b': '@2',
'sum': '@1 + @2',
'mul': '@1 * @2',
'pow': 'POW(@1, @2)'
}
});
相当于:
LOAD DATA LOCAL INFILE 'file.txt'
INTO TABLE `t1` (@1, @2)
SET
`a` = @1,
`b` = @2,
`sum` = @1 + @2,
`mul` = @1 * @2,
`pow` = POW(@1, @2);
不幸的是,目前 MySQL Shell 8.0.18 中的 util.importTable
不支持传递给列选项的用户变量。
您可以通过 ALTER TABLE 来解决此限制,并使用正确的列类型导入数据文件中存在的缺失列:
alter table names add column (dummy1 integer, dummy2 integer);
导入您的数据,例如/tmp/names.csv
[1]
util.importTable("/tmp/names.csv", {table:"names", columns: ["id", "firstname", "dummy1", "dummy2", "lastname"], dialect: "csv-unix"})
并删除虚拟
列:
alter table names drop column dummy1;
alter table names drop column dummy2;
或者简单地调用 LOAD DATA LOCAL INFILE SQL 命令:
LOAD DATA LOCAL INFILE '/tmp/sample.csv'
INTO TABLE myschema.mytable
(id, firstname, @dummy, @dummy, lastname);
[1]示例数据/tmp/names.csv
1,"Nicole",71,29,"Tusk"
2,"Bob",49,66,"Schiffer"
3,"Susan",61,17,"Tusk"
4,"Bob",24,59,"Trump"
5,"Nicole",25,46,"Goldberg"
6,"Bob",16,71,"Goldberg"
7,"Mark",43,43,"Schiffer"
关于mysql - 如何在 mysqlsh importTable util 中跳过/虚拟列?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58526208/
我在这个网站上发布的代码有这个问题 https://developers.google.com/drive/quickstart-cs是 Google Drive 快速入门的开发人员站点。我按照网站上
我正在尝试制作一个非常简单的 Kafka Producer,目前正在关注 producer example除了我的制作人没有分区程序类。 将所需文件导出到 jar 后,我将它们传输到我的 Linux
问题 在java中,我有一个“Util项目”,在进行单元测试时使用另一个“Mock项目”。 我的问题是“模拟项目”也使用“Util项目”来构建一些模拟对象。 当我使用 Maven 构建项目时,我无法构
据我所知,这些包已经存在很长时间了。但是,我从未见过它们的实际用法。而且这些包似乎不成熟,不再维护。如果是,为什么这些包现在存在? 最佳答案 包裹automata被 scala.xml.dtd 使用,
关闭。这个问题需要debugging details .它目前不接受答案。 想改进这个问题?将问题更新为 on-topic对于堆栈溢出。 1年前关闭。 Improve this question Co
在java.util.Collections中,有一个方法: public static void fill(List list, T obj) 用第二个参数指定的对象填充第一个参数指定的List。
我不明白它要我做什么。分配给 sentence正在工作: val sentences : java.util.List[CoreMap] = document.get(classOf[Sentence
在我的 React 应用程序中,我想使用一些实用程序。我见过两种不同的方法。第一个是,只是创建函数并将其导出。第二个是,创建一个 Util 类并导出一个对象,这样它就不能被实例化(静态类)。 clas
我有一个 util 类,它接受 String jwtToken 和 Key key 并使用 io.jsonwebtoken.jwts 解码 jwt。 但是,我无法对此进行测试。原因是,我无法模拟公钥并
我有使用目标命名空间的专有架构 xmlns:ax216="http://util.java/xsd" 这给我带来了从 java (java.util.xsd) 开始生成禁止的(由 Java 安全管理器
我正在阅读集合以查看 Javadocs 中的实现层次结构。 Collections声明为public class Collections extendds Object Collection声明为pu
我正在使用 Spring-boot 应用程序,我可以在其中连接 Azure 应用程序配置。但是当我尝试使用内容类型应用程序/JSON 读取值时出现错误。 我的Java类 @ConfigurationP
我正在使用 Spring-boot 应用程序,我可以在其中连接 Azure 应用程序配置。但是当我尝试使用内容类型应用程序/JSON 读取值时出现错误。 我的Java类 @ConfigurationP
我在使用格式说明符时遇到问题。这是否意味着我正在使用 %d? public static void main(String[] args) { double y, x; for (x =
鉴于此代码 import java.util.Iterator; private static List someList = new ArrayList(); public static void
我正在 HackerEarth 解决问题,我无法弄清楚为什么我的程序在命令行上正确运行并给出正确的结果,但在代码编辑器上运行时却给出 java.util.NoSuchElementException
我正在尝试使用以下代码使用对象列表列表中的数据填充tableModel readExcel.readSheet(0): TableModel tableModel = new DefaultTabl
java.util.Set 、 java.util.List 和其他 Collection 接口(interface)不可序列化。需要一个简单、直接的解决方案来在可序列化的 POJO 中使用它。 pu
我试图从 servlet 返回数据库搜索结果的 ArrayList 以显示在 jsp 页面上。 在servlet中设置arraylist作为请求的属性,并将请求转发到jsp页面。当我尝试在 jsp 页
我是android新手,最近我试图从firebase中提取数据到recyclerview/cardview中以垂直布局显示数据,它显示将Hashmap转换为Arraylist的错误,其中代码是:
我是一名优秀的程序员,十分优秀!