[root@server1 sqoop]# bin/sqoop import-all-tables \ > --connect jdbc:mysql://192.168.88.132:3306/meta_erp_data \ > --username root \ > --password 666666 \ > --create-hive-database meta_erp_data \ > --hive-import --create-hive-table 2023-05-26 18:26:04,495 INFO sqoop.Sqoop: Running Sqoop version: 1.4.6-cdh5.14.2 2023-05-26 18:26:04,666 WARN tool.BaseSqoopTool: Setting your password on the command-line is insecure. Consider using -P instead. 2023-05-26 18:26:04,667 ERROR tool.BaseSqoopTool: Error parsing arguments for import-all-tables: 2023-05-26 18:26:04,667 ERROR tool.BaseSqoopTool: Unrecognized argument: --create-hive-database 2023-05-26 18:26:04,667 ERROR tool.BaseSqoopTool: Unrecognized argument: meta_erp_data 2023-05-26 18:26:04,667 ERROR tool.BaseSqoopTool: Unrecognized argument: --hive-import 2023-05-26 18:26:04,667 ERROR tool.BaseSqoopTool: Unrecognized argument: --create-hive-table Try --help for usage instructions.
时间: 2024-02-11 17:07:22 浏览: 357
根据您提供的错误信息,Sqoop无法识别`--create-hive-database`、`meta_erp_data`、`--hive-import`和`--create-hive-table`这些选项。这可能是因为您使用的Sqoop版本不支持这些选项。
请注意,`--create-hive-database`选项是从Sqoop 1.4.7版本开始支持的,而`--hive-import`和`--create-hive-table`选项是在Sqoop 1.4.0版本中引入的。因此,如果您的Sqoop版本太旧,则无法使用这些选项。
您可以尝试升级Sqoop版本,或者使用以下命令来导入所有表:
```
sqoop import-all-tables --connect jdbc:mysql://192.168.88.132:3306/meta_erp_data --username root --password 666666 --hive-import --hive-database meta_erp_data
```
这将从MySQL中导入所有表,并将它们存储到名为`meta_erp_data`的Hive数据库中。
相关问题
#!/bin/bash sqoop job --delete haibaicai sqoop job --create haibaicai \ -- import \ --connect jdbc:mysql://192.168.253.128:3306:3306/dbhome \ --driver com.mysql.jdbc.Driver \ --username root \ --password-file /sqoop/pwd/sqoopPWD.pwd \ --table haibaicai \ --delete-target-dir \ --target-dir /user/hive/warehouse/dbhome.db/haibaicai \ --fields-terminated-by '\001' sqoop job --exec haibaicai
这个脚本的作用是使用sqoop将MySQL中的haibaicai表导入到Hive的dbhome数据库中的haibaicai表中,导入时使用'\001'作为字段分隔符,并且在导入前会删除Hive中已有的目标目录。
但是,这个脚本中的一些参数可能存在问题:
1. `--connect`参数的URL是不正确的,应该是`jdbc:mysql://192.168.253.128:3306/dbhome`,不需要写两个冒号。
2. `--delete-target-dir`参数在一些版本的sqoop中已被弃用,可以使用`--delete-target-dir -m 1`替代。
3. `--fields-terminated-by`参数应该是`--fields-terminated-by '\001'`,而不是`--fields-terminated-by \001`。
建议您对脚本进行以下修改:
```
#!/bin/bash
sqoop job --delete haibaicai
sqoop job --create haibaicai \
--import \
--connect jdbc:mysql://192.168.253.128:3306/dbhome \
--driver com.mysql.jdbc.Driver \
--username root \
--password-file /sqoop/pwd/sqoopPWD.pwd \
--table haibaicai \
--delete-target-dir -m 1 \
--target-dir /user/hive/warehouse/dbhome.db/haibaicai \
--fields-terminated-by '\001'
sqoop job --exec haibaicai
```
这个修改后的脚本应该可以正常运行了。
mysql> sqoop import --connect jdbc:mysql://192.168.204.128:3306/ua1 --username root -P --table EMP -target-dir /user/yyl/zhangsan -m 1; ERROR 1064 (42000): You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'sqoop import --connect jdbc:mysql://192.168.204.128:3306/ua1 --username root -P ' at line 1
这个错误提示看起来像是在 MySQL 命令行中执行了 Sqoop 命令,导致语法不正确。Sqoop 是一款用于在 Hadoop 生态系统中实现关系型数据库和 Hadoop 之间数据的传输的工具,需要在命令行中执行,而非 MySQL 命令行。请先退出 MySQL 命令行,再在命令行中执行该命令。另外,您需要确认您的 Sqoop 已正确安装和配置,并且目标 Hadoop 集群已正常运行。
阅读全文
相关推荐

















