sqoop的sql语言导入方式

bash 复制代码
sqoop import \
--connect jdbc:mysql://node00:3306/sqoop_export \
--username root \
--password 1234567 \
--target-dir /sqoop/emp3 \
--delete-target-dir \
--query "select * from emp_out where id<1203 and \$CONDITIONS" \
--input-fields-terminated-by "," \
--split-by id

这段 Sqoop 代码的主要作用是从 MySQL 数据库中导入符合特定条件的数据到 Hadoop 的 HDFS 中,下面为你详细解释代码中各部分的含义:

整体功能概述

就好比你有一个装满各种物品的大仓库(MySQL 数据库),你想要把仓库里某些特定的物品(符合条件的数据)挑选出来,然后搬到另一个大的存储场地(HDFS)里去,Sqoop 就像是负责搬运这些物品的 "搬运工"。

代码逐行解释

sqoop import

这是 Sqoop 的导入命令,意思就是要把数据从其他数据源(这里是 MySQL 数据库)导入到 Hadoop 的 HDFS 中,类似于告诉 "搬运工" 要开始从仓库往存储场地搬东西了。

--connect jdbc:mysql://node00:3306/sqoop_export
  • --connect:指定要连接的数据源地址。
  • jdbc:mysql://:表示使用 JDBC 协议连接 MySQL 数据库。
  • node00:是 MySQL 数据库所在服务器的主机名或者 IP 地址,就像是仓库所在的具体位置。
  • 3306:是 MySQL 数据库的默认端口号,相当于进入仓库的 "门牌号"。
  • sqoop_export:是要连接的 MySQL 数据库的名称,也就是仓库里具体的一个存放区域。
--username root

指定连接 MySQL 数据库使用的用户名,这里是 root,可以理解为进入仓库需要的身份凭证中的用户名部分。

--password 1234567

指定连接 MySQL 数据库使用的密码,这里是 123456,相当于身份凭证中的密码部分,和用户名一起才能成功进入仓库。

--target-dir /sqoop/emp3

指定数据导入到 HDFS 中的目标目录,即 /sqoop/emp3,这就好比告诉 "搬运工" 把挑选好的物品放到存储场地的哪个具体位置。

--delete-target-dir

在导入数据之前,先删除目标目录(也就是 /sqoop/emp3)下的所有内容。这就像是在把新物品放到存储场地的指定位置之前,先把这个位置原来的东西都清理掉。

--query "select * from emp_out where id<1203 and \$CONDITIONS"
  • --query:用于指定从数据库中查询数据的 SQL 语句。
  • select * from emp_out:表示从 emp_out 表中查询所有列的数据,emp_out 表就像是仓库里的一个货架。
  • where id<1203:是查询的过滤条件,只选取 id 小于 1203 的记录,相当于只挑选货架上编号小于 1203 的物品。
  • and \$CONDITIONS:这是 Sqoop 要求的固定写法,用于在并行导入时添加额外的查询条件,保证数据正确分割。
--input-fields-terminated-by ","

指定从数据库中读取的数据字段之间的分隔符为逗号 ,。可以想象成仓库里的物品是按照逗号来区分不同属性的,搬运工在搬运过程中也按照这个规则来处理。

--split-by id

指定按照 id 字段对数据进行分割,以便进行并行导入。这就好比把要搬运的物品按照编号分成不同的批次,多个 "搬运工" 可以同时搬运不同批次的物品,提高搬运效率。

--query "select * from emp_out where id<1203 and \$CONDITIONS"单引号与双引号?

使用双引号的情况:

bash 复制代码
sqoop import \
--connect jdbc:mysql://node00:3306/sqoop_export \
--username root \
--password 123456 \
--target-dir /sqoop/emp3 \
--delete-target-dir \
--query "select * from emp_out where id<1203 and \$CONDITIONS" \
--input-fields-terminated-by "," \
--split-by id
  • 变量解析 :在大多数 shell 环境(如 Bash)中,双引号会让 shell 对其中的变量进行解析。在上述例子里,$CONDITIONS 是 Sqoop 需要的一个特殊占位符,用于并行导入时添加额外的查询条件。使用双引号时,需要对 $ 进行转义(即写成 \$),否则 shell 会尝试去解析 $CONDITIONS 这个变量,而它在 shell 环境中通常是没有定义的,就会导致错误。
  • 优点:适合需要在查询语句中嵌入 shell 变量的情况。例如,如果你想动态地根据某个 shell 变量来构建查询条件,可以这样做:

使用单引号的情况:

bash 复制代码
sqoop import \
--connect jdbc:mysql://node00:3306/sqoop_export \
--username root \
--password 123456 \
--target-dir /sqoop/emp3 \
--delete-target-dir \
--query 'select * from emp_out where id<1203 and $CONDITIONS' \
--input-fields-terminated-by "," \
--split-by id
  • 禁止变量解析 :单引号会阻止 shell 对其中的内容进行变量解析,所以 $CONDITIONS 会原样传递给 Sqoop,不会被 shell 误解。这样就不需要对 $ 进行转义。
  • 优点:当查询语句中不涉及 shell 变量时,使用单引号可以避免变量解析带来的潜在问题,让查询语句更加简洁和直观。

总结

  • 如果查询语句中需要嵌入 shell 变量,使用双引号,但要注意对特殊字符(如 $)进行转义。
  • 如果查询语句中没有需要 shell 解析的变量,使用单引号更为方便和安全。
相关推荐
小陈工1 小时前
Python Web开发入门(十七):Vue.js与Python后端集成——让前后端真正“握手言和“
开发语言·前端·javascript·数据库·vue.js·人工智能·python
xiaotao1315 小时前
第九章:Vite API 参考手册
前端·vite·前端打包
午安~婉6 小时前
Electron桌面应用聊天(续)
前端·javascript·electron
一江寒逸6 小时前
零基础从入门到精通MySQL(中篇):进阶篇——吃透多表查询、事务核心与高级特性,搞定复杂业务SQL
数据库·sql·mysql
彧翎Pro6 小时前
基于 RO1 noetic 配置 robosense Helios 32(速腾) & xsense mti 300
前端·jvm
小码哥_常6 小时前
解锁系统设置新姿势:Activity嵌入全解析
前端
之歆7 小时前
前端存储方案对比:Cookie-Session-LocalStorage-IndexedDB
前端
哟哟耶耶7 小时前
vue3-单文件组件css功能(:deep,:slotted,:global,useCssModule,v-bind)
前端·javascript·css
是罐装可乐7 小时前
深入理解“句柄(Handle)“:从浏览器安全到文件系统访问
前端·javascript·安全
华科易迅7 小时前
Vue如何集成封装Axios
前端·javascript·vue.js