大数据开发学习Day23

一、Linux

不解压,直接查看压缩包内文件内容
递归统计当前目录下所有文件总行数
查看服务器开机运行时长

bash 复制代码
zcat app.log.gz
find . -type f -exec cat {} \; | wc -l
uptime

二、SQL

610. 判断三角形

sql 复制代码
SELECT
    x, y, z,
    CASE
        WHEN x + y > z AND x + z > y AND y + z > x
        THEN 'Yes'
        ELSE 'No'
    END AS triangle
FROM Triangle;

CASE 多条件分支 自定义字段

三角形判定核心:任意两边之和大于第三边

单列衍生标签,数仓打标签通用写法

619. 只出现一次的最大数字

sql 复制代码
SELECT MAX(num) AS num
FROM (
    SELECT num
    FROM MyNumbers
    GROUP BY num
    HAVING COUNT(*) = 1
) t;

内层分组筛选单次数据

外层聚合取最大值

子查询嵌套、极值统计经典模板

1075. 项目员工 I

sql 复制代码
SELECT
    p.project_id,
    ROUND(AVG(e.experience_years), 2) AS average_years
FROM Project p
LEFT JOIN Employee e
ON p.employee_id = e.employee_id
GROUP BY p.project_id;

多表 LEFT JOIN 关联维度表

AVG + ROUND 保留小数

项目 / 团队维度指标统计,贴合业务报表

三、Pyspark

python 复制代码
from pyspark.sql import SparkSession
from pyspark.sql.functions import col, avg, round, count

spark = SparkSession.builder.master("local[*]").appName("Day23").getOrCreate()

# 1. 条件打标签 对应 LC610
tri = spark.createDataFrame([(3,4,5),(1,2,3)],["x","y","z"])
tri.createOrReplaceTempView("triangle")
spark.sql("""
SELECT x,y,z,
CASE WHEN x+y>z AND x+z>y AND y+z>x THEN 'Yes' ELSE 'No' END AS triangle
FROM triangle
""").show()

# 2. 分组筛选+求最大 对应 LC619
num_df = spark.createDataFrame([(1,),(2,),(2,)],["num"])
num_df.groupBy("num").count().filter(col("count")==1)\
     .selectExpr("max(num) as num").show()

# 3. 多表关联+平均值保留2位 对应 LC1075
proj = spark.createDataFrame([(1,101),(1,102)],["project_id","employee_id"])
emp = spark.createDataFrame([(101,"A",3),(102,"B",5)],["employee_id","name","exp"])

proj.join(emp,on="employee_id")\
    .groupBy("project_id")\
    .agg(round(avg("exp"),2).alias("avg_year"))\
    .show()

spark.stop()

SparkSQL 直接复用 SQL 逻辑,快速迁移

分组过滤、聚合求值、小数保留

事实表 + 维度表关联,数仓日常开发标配

四、算法

python 复制代码
class ListNode:
    def __init__(self,val=0,next=None):
        self.val = val
        self.next = next

def reverseList(head):
    pre = None
    cur = head
    while cur:
        nxt = cur.next
        cur.next = pre
        pre = cur
        cur = nxt
    return pre
相关推荐
一楼的猫10 小时前
从工具链视角对比:番茄作家助手 vs 第三方写作辅助方案
java·服务器·开发语言·前端·学习·chatgpt·ai写作
qziovv10 小时前
Git 回退场景
大数据·git·elasticsearch
他们叫我阿冠10 小时前
实习前自我培训-Day1学习
学习
Upsy-Daisy11 小时前
AI Agent 项目学习笔记(七):RAG 高级扩展——过滤检索、PgVector 与云知识库
人工智能·笔记·学习
柿柿快乐11 小时前
Redis 入门第一课:全局命令、内部编码与单线程模型
redis·学习·缓存·基础教学
ZeroNews内网穿透11 小时前
面向 AI 协作的本地客户端能力:ZeroNews Agent Skills
大数据·人工智能·elasticsearch
SelectDB12 小时前
Agent 时代,为什么传统的可观测方案不适用了?
大数据·数据库·数据分析
Elastic 中国社区官方博客12 小时前
快 12 倍的 Elasticsearch 向量索引:使用 GPU 和 CPU 分层部署 NVIDIA cuVS
大数据·人工智能·elasticsearch·搜索引擎·ai·全文检索·nvidia
鹧鸪云光伏12 小时前
光伏设计软件:多屋脊房型如何设计?
大数据·信息可视化·光伏·光伏设计·光伏图纸
前沿推行者12 小时前
辽宁传媒学院教学特色解析:从实践导向到产教融合
大数据·人工智能