shell脚本总结2

目录

  • 实战
  • 解析和说明

实战

# 打印 datainfo 变量的值
echo $datainfo# 用逗号分隔符解析 datainfo,并将结果存储在一个数组中
var=(${datainfo//,/ })
mark_num=${var[0]}
begin_date=${var[1]}
end_date=${var[2]}# 打印解析出的变量
echo "Mark Number: $mark_num"
echo "Begin Date: $begin_date"
echo "End Date: $end_date"# 检查 mark_num 是否为 "NULL"
if [ "$mark_num" = "NULL" ]; thenexit -1
else# 执行 Spark SQL 查询spark3-sql \--driver-memory "10G" \--executor-memory "20G" \--executor-cores "4" \--conf spark.hadoop.lzo.text.input.format.ignore.nonlzo="false" \--conf spark.locality.wait="0s" \--conf spark.kryoserializer.buffer="512k" \--conf spark.grouping.sets.reference.hive="true" \--conf spark.dynamicAllocation.maxExecutors="200" \--conf spark.executor.memoryOverhead="6G" \--conf spark.dynamicAllocation.enabled="true" \--conf spark.locality.wait.rack="0s" \--hiveconf hive.cli.print.header="false" \--queue "root.mi.sh" \--e "SELECT day,imei,SUM(paly_cnt) AS paly_cnt,SUM(paly_time) AS paly_timeFROM default.testtable2WHERE day BETWEEN '$begin_date' AND '$end_date'GROUP BY day, imei"
fi

解析和说明

1.echo $dateinfo:
打印变量 dateinfo 的值。这个步骤主要用于调试或验证 dateinfo 内容是否正确。

2.var=(${dateinfo//,/ }):
将 dateinfo 中以逗号分隔的字符串转化为数组 var。这个用法利用了 Bash 的参数替换功能,将字符串中的所有逗号替换为空格,然后用圆括号将结果扩展为数组形式。

3.mark_num=${var[0]}:
赋值数组的第一个元素给 mark_num,对应最初 SQL 语句中 count(1) 的结果。

4.begin_date=${var[1]}:
赋值数组的第二个元素给 exper_startdate,对应 SQL 中 min(gray_day) 的结果。

5.end_date=${var[2]}:
赋值数组的第三个元素给 exper_enddate,对应 SQL 中 max(exper_date_end) 的结果。

6.echo $mark_num, echo $begin_date, echo $end_date:
分别打印 mark_num、exper_startdate 和 exper_enddate 的值,通常用于输出查看或进一步验证。

7.if [ “$mark_num” = “NULL” ] ;then:
检查 mark_num 是否为字符串 “NULL”。如果是,说明 SQL 查询可能未返回有效结果或数据,本段代码决定在这种情况下退出脚本。
exit -1:
如果 mark_num 是 “NULL”,执行此命令,脚本以状态码 -1 退出。负数作返回码是非标准用法,通常返回码应在 0-255 之间。

8.Spark SQL 执行
如果 mark_num 不是 “NULL”,则执行 spark3-sql 命令。这条 SQL 查询选择了 day、imei 以及一些聚合的计数与时间总和,条件是 day 在 begin_date 和 end_date 之间,并按 day 和 imei 分组。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/502998.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

计算机网络 (27)IP多播

前言 IP多播(也称多址广播或组播)技术是一种允许一台或多台主机(多播源)发送单一数据包到多台主机(一次性的、同时的)的TCP/IP网络技术。 一、基本概念 定义:多播作为一点对多点的通信&#xff…

CSS 学习之正确看待 CSS 世界里的 margin 合并

一、什么是 margin 合并 块级元素的上外边距(margin-top)与下外边距(margin-bottom)有时会合并为单个外边距,这样的现象称为“margin 合并”。从此定义上,我们可以捕获两点重要的信息。 块级元素,但不包括浮动和绝对定位元素,尽…

小程序组件 —— 28 组件案例 - 推荐商品区域 - 实现结构样式

这一节目标是实现底部推荐商品的结构和样式,由于这里要求横向滚动,所以需要使用上节介绍的 scroll-view 功能,并使用 scroll-x 属性支持横向滚动,推荐商品区域中的每一个商品是一个单独的 view,每个view 中需要写三个组…

单片机-LED点阵实验

要将第一个点点亮,则 1 脚接高电平 a 脚接低电平,则第一个点就亮了;如果要将第一行点亮,则第 1 脚要接高电平,而(a、b、c、d、e、f、g、h )这些引脚接低电平,那么第一行就会点亮&…

软件项目体系建设文档,项目开发实施运维,审计,安全体系建设,验收交付,售前资料(word原件)

软件系统实施标准化流程设计至关重要,因为它能确保开发、测试、部署及维护等各阶段高效有序进行。标准化流程能减少人为错误,提升代码质量和系统稳定性。同时,它促进了团队成员间的沟通与协作,确保项目按时交付。此外,…

Java基础 注解

分类 Java自带的标准注解,包括Override、Deprecated和SuppressWarnings,分别用于标明重写某个方法、标明某个类或方法过时、标明要忽略的警告,用这些注解标明后编译器就会进行检查。元注解,元注解是用于定义注解的注解&#xff0…

Linux中rsync命令使用

一、rsync简介 rsync 是一种高效的文件复制和同步工具,常用于在本地或远程计算机之间同步文件和目录 主要特性增量同步:rsync 会检测源和目标文件之间的差异,只传输发生变化的部分,而不是重新传输整个文件。这样就能有效减少数据…

基于STM32的自动水满报警系统设计

目录 引言系统设计 硬件设计软件设计系统功能模块 水位检测模块报警模块自动控制模块控制算法 水位检测逻辑报警触发逻辑代码实现 水位检测模块报警控制模块自动控制逻辑系统调试与优化结论与展望 1. 引言 水满报警系统在家庭、农业、工业等领域广泛应用,通过实时…

【Java数据结构】二叉树

1.树型结构 1.1树的概念 树是一种非线性的数据结构,由n个结点组成的具有层次关系的集合。下面是它的特点: 根结点是没有前驱的结点(没有父结点的结点)子结点之间互不相交除了根结点外,其它结点都只有一个父结点n个结…

学习threejs,导入AWD格式的模型

👨‍⚕️ 主页: gis分享者 👨‍⚕️ 感谢各位大佬 点赞👍 收藏⭐ 留言📝 加关注✅! 👨‍⚕️ 收录于专栏:threejs gis工程师 文章目录 一、🍀前言1.1 ☘️THREE.AWDLoader AWD模型加…

Chapter4.3:Implementing a feed forward network with GELU activations

4 Implementing a GPT model from Scratch To Generate Text 4.3 Implementing a feed forward network with GELU activations 本节即将实现子模块,用于transformer block(变换器块)的一部分。为此,我们需要从激活函数开始。 深…

弥散张量分析开源软件 DSI Studio 简体中文汉化版可以下载了

网址: (63条消息) DSIStudio简体中文汉化版(2022年7月)-算法与数据结构文档类资源-CSDN文库

【信号滤波 (补充)】二阶陷波滤波代码推导过程(C++)

目录 二阶陷波滤波器计算实例一、 传递函数的参数推导1. 首先 b 0 , b 1 , b 2 b_0, b_1, b_2 b0​,b1​,b2​是怎么推导出来的?2. 带入实际值求解3. 验证上述的传递函数 二、将传递函数转化成差分方程2.1 传递函数写成输入输出形式2.2 Z域转化为时域 三、将差分方程…

C++进阶——用Hash封装unordered_map和unordered_set

目录 前言 源码怎么说 为什么要兼容? 兼容的具体做法? 为什么要把Key转为整数(HashFcn)? 模拟实现 一、建立框架 二、迭代器 运算符重载 迭代器兼容大法 三、[ ]重载 四、实现不能修改key 实现及测试代码 …

安装MySQL的五种方法(Linux系统和Windows系统)

一.在Linux系统中安装MySQL 第一种方法:在线YUM仓库 首先打开MySQL官网首页 www.mysql.com 找到【DOWNLOADS】选项,点击 下拉,找到 【MySQL Community(GPL) Downloads】 在社区版下载页面中,【 MySQL Yum Repository 】链接为在线仓库安装…

极客说|微软 Phi 系列小模型和多模态小模型

作者:胡平 - 微软云人工智能高级专家 「极客说」 是一档专注 AI 时代开发者分享的专栏,我们邀请来自微软以及技术社区专家,带来最前沿的技术干货与实践经验。在这里,您将看到深度教程、最佳实践和创新解决方案。关注「极客说」&am…

封装/前线修饰符/Idea项目结构/package/impore

目录 1. 封装的情景引入 2. 封装的体现 3. 权限修饰符 4. Idea 项目结构 5. package 关键字 6. import 关键字 7. 练习 程序设计:高内聚,低耦合; 高内聚:将类的内部操作“隐藏”起来,不需要外界干涉&#xff1b…

【C++】P5733 【深基6.例1】自动修正

博客主页: [小ᶻ☡꙳ᵃⁱᵍᶜ꙳] 本文专栏: C 文章目录 💯前言💯题目描述💯解题思路概述💯第一种实现方式:直接使用字符ASCII值计算代码实现代码分析 💯第二种实现方式:直接修改…

【Elasticsearch】文档操作:添加、更新和删除

🧑 博主简介:CSDN博客专家,历代文学网(PC端可以访问:https://literature.sinhy.com/#/?__c1000,移动端可微信小程序搜索“历代文学”)总架构师,15年工作经验,精通Java编…

【insert 插入数据语法合集】.NET开源ORM框架 SqlSugar 系列

系列文章目录 🎀🎀🎀 .NET开源 ORM 框架 SqlSugar 系列 🎀🎀🎀 文章目录 系列文章目录一、前言 🍃二、插入方式 💯2.1 单条插入实体2.2 批量 插入实体2.3 根据字典插入2.4 根据 Dat…