最新资讯

  • 26-学习笔记尚硅谷数仓搭建-DIM层特殊的维度表——用户维度表的建表、分析及DIM层数据装载脚本

26-学习笔记尚硅谷数仓搭建-DIM层特殊的维度表——用户维度表的建表、分析及DIM层数据装载脚本

2026-01-30 08:13:10 栏目:最新资讯 4 阅读

目录

一、完整的建表及数据装载代码(含注释)

二、拉链表设计思路

三、代码详解(结合例子讲解)

四、为什么不用JOIN?

五、这样设计的好处总结

六、数据装载脚本


一、完整的建表及数据装载代码(含注释)

-- ---------- 1. 创建用户维度拉链表 ----------
DROP TABLE IF EXISTS dim_user_zip;
CREATE EXTERNAL TABLE dim_user_zip
(
    `id`           STRING COMMENT '用户ID',
    `name`         STRING COMMENT '用户姓名',
    `phone_num`    STRING COMMENT '手机号码',
    `email`        STRING COMMENT '邮箱',
    `user_level`   STRING COMMENT '用户等级',
    `birthday`     STRING COMMENT '生日',
    `gender`       STRING COMMENT '性别',
    `create_time`  STRING COMMENT '创建时间',
    `operate_time` STRING COMMENT '操作时间',
    `start_date`   STRING COMMENT '开始日期',
    `end_date`     STRING COMMENT '结束日期'
) COMMENT '用户维度表'
    PARTITIONED BY (`dt` STRING)
    STORED AS ORC
    LOCATION '/warehouse/gmall/dim/dim_user_zip/'
    TBLPROPERTIES ('orc.compress' = 'snappy');

-- ---------- 2. 首日装载(第一次初始化数据) ----------
-- 首次将全部用户数据导入拉链表,所有数据都是当前有效的
insert overwrite table dim_user_zip partition (dt = '9999-12-31')
select
    data.id,  -- 用户ID,直接取原值

    -- 姓名脱敏:只保留姓氏,名字用*代替
    -- 示例:张三 -> 张*
    concat(substr(data.name, 1, 1), '*') name,

    -- 手机号处理:验证格式 + 脱敏
    -- 1. 先用正则验证是否是有效手机号(11位,符合中国手机号规则)
    -- 2. 如果有效:保留前3位,后8位用**代替(13812345678 -> 138**)
    -- 3. 如果无效:设为NULL
    if(data.phone_num regexp '^(13[0-9]|14[01456879]|15[0-35-9]|16[2567]|17[0-8]|18[0-9]|19[0-35-9])d{8}$',
        concat(substr(data.phone_num, 1, 3), '**'),
        null) phone_num,

    -- 邮箱处理:验证格式 + 脱敏
    -- 1. 验证邮箱格式是否正确
    -- 2. 如果正确:保留@后面部分,前面用*代替(zhangsan@example.com -> *@example.com)
    -- 3. 如果不正确:设为NULL
    if(data.email regexp '[a-zA-Z0-9-_]+@[a-zA-Z0-9_-]+(.[a-zA-Z0-9_-]+)+$',
        concat('*', split(data.email, '@')[1]),
        null) email,

    data.user_level,      -- 用户等级,直接取原值
    data.birthday,        -- 生日,直接取原值
    data.gender,          -- 性别,直接取原值
    data.create_time,     -- 创建时间,直接取原值
    data.operate_time,    -- 操作时间,直接取原值

    -- 拉链表核心字段:
    '2022-06-08' start_date,  -- 开始日期:因为是首日,所以是当天
    '9999-12-31' end_date     -- 结束日期:未来很远的一天,表示当前有效

-- 数据来源:原始数据表(ods层)
from ods_user_info_inc
-- 筛选条件:
where dt = '2022-06-08'                -- 分区日期:2022年6月8日
  and type = 'bootstrap-insert';       -- 数据类型:全量初始化数据

-- ---------- 3. 每日装载(每天增量更新) ----------
-- 说明:每天执行一次,处理前一天的用户信息变化

-- 设置动态分区模式,允许自动创建新分区
set hive.exec.dynamic.partition.mode=nonstrict;
insert overwrite table dim_user_zip partition (dt)
select id,
       name,
       phone_num,
       email,
       user_level,
       birthday,
       gender,
       create_time,
       operate_time,
       start_date,
        -- 处理结束日期(end_date):
        -- 情况1:如果是历史数据(rn=2),结束日期设为前一天(表示到前一天为止有效)
        -- 情况2:如果是最新数据(rn=1),保持原来的结束日期(9999-12-31)
       if(rn = 2, date_sub('2022-06-09', 1), end_date)     end_date,
        -- 处理分区字段(dt):
        -- 情况1:如果是最新数据(rn=1),放入'9999-12-31'分区
        -- 情况2:如果是历史数据(rn=2),放入前一天的分区('2022-06-08')
       if(rn = 1, '9999-12-31', date_sub('2022-06-09', 1)) dt
from (
         select id,
                name,
                phone_num,
                email,
                user_level,
                birthday,
                gender,
                create_time,
                operate_time,
                start_date,
                end_date,
                -- 关键窗口函数:给每个用户的数据编号
                -- partition by id:按用户ID分组
                -- order by start_date desc:按开始日期倒序排列(最新的排第一)
                -- rn=1:最新数据  rn=2:历史数据
                row_number() over (partition by id order by start_date desc) rn
         from (
                  select id,
                         name,
                         phone_num,
                         email,
                         user_level,
                         birthday,
                         gender,
                         create_time,
                         operate_time,
                         start_date,
                         end_date
                  from dim_user_zip
                  where dt = '9999-12-31'
                  union
                  select id,
                         concat(substr(name, 1, 1), '*')                name,
                         if(phone_num regexp
                            '^(13[0-9]|14[01456879]|15[0-35-9]|16[2567]|17[0-8]|18[0-9]|19[0-35-9])d{8}$',
                            concat(substr(phone_num, 1, 3), '*'), null) phone_num,
                         if(email regexp '^[a-zA-Z0-9_-]+@[a-zA-Z0-9_-]+(.[a-zA-Z0-9_-]+)+$',
                            concat('*@', split(email, '@')[1]), null)   email,
                         user_level,
                         birthday,
                         gender,
                         create_time,
                         operate_time,
                         '2022-06-09'                                   start_date,
                         '9999-12-31'                                   end_date
                  from (
                           select data.id,
                                  data.name,
                                  data.phone_num,
                                  data.email,
                                  data.user_level,
                                  data.birthday,
                                  data.gender,
                                  data.create_time,
                                  data.operate_time,
                                  row_number() over (partition by data.id order by ts desc) rn
                           from ods_user_info_inc
                           where dt = '2022-06-09'
                       ) t1
                  where rn = 1
              ) t2
     ) t3;

二、拉链表设计思路

1. 什么是拉链表?
拉链表就像一条可以拉伸的链子,记录了每条数据从开始到结束的有效时间范围。它有两个关键字段:

start_date:这条记录开始生效的日期

end_date:这条记录结束有效的日期

2. 分区设计(为什么有两个分区?)
sql
-- 分区字段:dt
-- 1. '9999-12-31'分区:保存当前最新的、正在使用的数据
-- 2. 普通日期分区(如'2022-06-08'):保存已经过期的历史数据
为什么要这样设计?

查询最新数据快:要查用户最新信息,直接查dt='9999-12-31'分区

查询历史数据方便:要查某天的用户信息,就查对应日期的分区

数据管理清晰:新老数据分开存放,不混在一起

3. 数据流向理解
首日(数据仓库第一次建表):
把所有用户的最新数据都放进9999-12-31分区

这时候start_date是当天日期,end_date是'9999-12-31'(表示一直有效)

每日更新:
新增用户:直接插入到9999-12-31分区

修改用户:比如小明的等级从1变成2

把原来9999-12-31分区里小明的旧记录拿出来
修改它的end_date为昨天(表示到昨天为止有效)
把这条旧记录放入昨天的分区(如dt='2022-06-08')
把小明的新记录(等级2)放入9999-12-31分区


三、代码详解(结合例子讲解)


1. 创建表语句解读
sql
CREATE EXTERNAL TABLE dim_user_zip
(
    'id' STRING COMMENT '用户ID',          -- 用户的唯一标识,如"user_001"
    'name' STRING COMMENT '用户姓名',       -- 用户真实姓名
    'phone_num' STRING COMMENT '手机号',   -- 用户手机号
    'email' STRING COMMENT '邮箱',         -- 用户邮箱
    'user_level' STRING COMMENT '用户等级', -- 如"VIP1"、"普通会员"
    'birthday' STRING COMMENT '生日',      -- 用户生日
    'gender' STRING COMMENT '性别',        -- 男/女
    'create_time' STRING COMMENT '创建时间', -- 用户注册时间
    'operate_time' STRING COMMENT '操作时间', -- 最后操作时间
    'start_date' STRING COMMENT '开始日期', -- 这条记录生效的开始日期
    'end_date' STRING COMMENT '结束日期'    -- 这条记录生效的结束日期
) COMMENT '用户维度表';

-- 按dt字段分区,就像把文件放进不同的文件夹
PARTITIONED BY ('dt' STRING)
-- 使用ORC格式存储(一种高效的数据存储格式)
STORED AS ORC
-- 数据存放的位置
LOCATION '/warehouse/gmall/dim/dim_user_zip/'
-- 设置压缩格式为snappy(减少存储空间)
TBLPROPERTIES ('orc.compress' = 'snappy');
2. 重要函数讲解
(1)数据脱敏函数(保护用户隐私)
sql
-- 1. 姓名脱敏:只显示第一个字,后面用*代替
-- 例如:"张三" -> "张*"
concat(substr(data.name, 1, 1), '*')

-- 2. 手机号脱敏:保留前3位,后面用**代替
-- 例如:"13812345678" -> "138**"
concat(substr(data.phone_num, 1, 3), '**')

-- 3. 邮箱脱敏:@符号后面的部分保留,前面用*代替
-- 例如:"zhangsan@example.com" -> "*@example.com"
concat('*', split(data.email, '@')[1])
(2)正则表达式函数(数据验证)
sql
-- 验证手机号格式是否正确(11位数字,符合中国手机号规则)
-- regexp是正则表达式匹配函数
data.phone_num regexp '^(13[0-9]|14[01456879]|15[0-35-9]|16[2567]|17[0-8]|18[0-9]|19[0-35-9])d{8}$'

-- 验证邮箱格式是否正确
data.email regexp '[a-zA-Z0-9-_]+@[a-zA-Z0-9_-]+(.[a-zA-Z0-9_-]+)+$'
(3)窗口函数(处理排名)
sql
-- row_number() over:给每组数据编号
-- partition by id:按用户ID分组
-- order by start_date desc:按开始日期倒序排列(最新的排第一)
row_number() over (partition by id order by start_date desc) rn
作用:给每个用户的数据编号,最新的是1,次新的是2,依此类推。

3. 首日装载代码讲解(第一次导入数据)
sql
-- 向dim_user_zip表的9999-12-31分区插入数据
insert overwrite table dim_user_zip partition (dt = '9999-12-31')

select 
    data.id,  -- 用户ID
    -- 姓名脱敏:只显示姓,名用*代替
    concat(substr(data.name, 1, 1), '*') name,
    
    -- 手机号处理:先验证格式,如果正确就脱敏,否则设为null
    if(data.phone_num regexp '^(13[0-9]|14[01456879]|15[0-35-9]|16[2567]|17[0-8]|18[0-9]|19[0-35-9])d{8}$', 
        concat(substr(data.phone_num, 1, 3), '**'), 
        null) phone_num,
    
    -- 邮箱处理:先验证格式,如果正确就脱敏,否则设为null
    if(data.email regexp '[a-zA-Z0-9-_]+@[a-zA-Z0-9_-]+(.[a-zA-Z0-9_-]+)+$', 
        concat('*', split(data.email, '@')[1]), 
        null) email,
    
    data.user_level,      -- 用户等级
    data.birthday,        -- 生日
    data.gender,          -- 性别
    data.create_time,     -- 创建时间
    data.operate_time,    -- 操作时间
    
    '2022-06-08' start_date,  -- 开始日期是今天(因为是首日)
    '9999-12-31' end_date     -- 结束日期是很远的未来,表示当前有效

-- 从原始数据表取数据
from ods_user_info_inc 
where dt = '2022-06-08'      -- 取今天的数据
  and type = 'bootstrap-insert';  -- 只取全量导入的数据
4. 每日装载代码讲解(每天更新数据)
这是最关键的部分,我们用一个具体例子来理解:

场景:2022年6月9日,用户"user_001"的手机号从"13812345678"改为"13987654321"

sql
-- 设置动态分区模式(允许自动创建分区)
set hive.exec.dynamic.partition.mode=nonstrict; 

-- 更新dim_user_zip表
insert overwrite table dim_user_zip partition (dt)

select 
    id, name, phone_num, email, user_level, birthday, gender, 
    create_time, operate_time, start_date,
    
    -- 处理结束日期:
    -- 如果rn=2(历史记录),结束日期设为昨天(2022-06-08)
    -- 如果rn=1(最新记录),保持原来的end_date
    if(rn = 2, date_sub('2022-06-09', 1), end_date) end_date,
    
    -- 处理分区dt:
    -- 如果rn=1(最新记录),放入'9999-12-31'分区
    -- 如果rn=2(历史记录),放入昨天分区('2022-06-08')
    if(rn = 1, '9999-12-31', date_sub('2022-06-09', 1)) dt

from (
    -- 步骤2:给新旧数据编号(每个用户的最新数据是1,历史数据是2)
    select 
        id, name, phone_num, email, user_level, birthday, gender,
        create_time, operate_time, start_date, end_date,
        -- 关键:按用户分组,按开始日期倒序排名
        row_number() over (partition by id order by start_date desc) rn
    from (
        -- 步骤1:合并新旧数据
        -- 1.1 从拉链表取当前最新的数据(旧数据)
        select 
            id, name, phone_num, email, user_level, birthday, gender,
            create_time, operate_time, start_date, end_date
        from dim_user_zip 
        where dt = '9999-12-31'  -- 只取最新的数据
        
        union all  -- 合并
        
        -- 1.2 从原始表取今天变更的数据(新数据)
        select 
            id, 
            concat(substr(name, 1, 1), '*') name,  -- 脱敏
            if(phone_num regexp '^(13[0-9]|14[01456879]|15[0-35-9]|16[2567]|17[0-8]|18[0-9]|19[0-35-9])d{8}$', 
                concat(substr(phone_num, 1, 3), '**'), 
                null) phone_num,  -- 脱敏
            if(email regexp '[a-zA-Z0-9-_]+@[a-zA-Z0-9_-]+(.[a-zA-Z0-9_-]+)+$', 
                concat('*', split(email, '@')[1]), 
                null) email,  -- 脱敏
            user_level, birthday, gender, create_time, operate_time,
            '2022-06-09' start_date,  -- 新数据的开始日期是今天
            '9999-12-31' end_date     -- 新数据的结束日期是未来
        from ods_user_info_inc 
        where dt = '2022-06-09'  -- 今天的数据
          and type in ('insert', 'update')  -- 新增或修改的数据
    ) t1
) t2;


四、为什么不用JOIN?


这是一个很好的问题!很多人会想:为什么不直接用JOIN把新旧数据连起来呢?

JOIN方式的缺点:
数据膨胀:如果一个用户有10次变更,JOIN会产生10条关联记录

查询复杂:要查最新数据需要复杂的子查询

性能差:每天全表JOIN,数据量大时非常慢

拉链表的优势:
查询简单:

sql
-- 查最新数据(简单)
select * from dim_user_zip where dt = '9999-12-31';

-- 查某天数据(简单)
select * from dim_user_zip where dt = '2022-06-08';
历史追踪容易:

sql
-- 查用户"user_001"的所有历史变化
select * from dim_user_zip where id = 'user_001' order by start_date;
存储高效:每个用户每天只有一条有效记录

五、这样设计的好处总结


保存完整历史:用户信息的每次变化都被记录下来

查询性能高:按分区查询,速度快

数据管理方便:新数据和老数据分开存放

节省存储空间:相比每天全量快照,拉链表更节省空间

支持时间旅行:可以查询任意时间点的用户状态

六、数据装载脚本

1.首日全量脚本

cd /home/atguigu/bin
vim ods_to_dim_init.sh 

添加下面的内容:

#!/bin/bash

APP=gmall

if [ -n "$2" ] ;then
   do_date=$2
else 
   echo "请传入日期参数"
   exit
fi 

dim_user_zip="
insert overwrite table ${APP}.dim_user_zip partition (dt = '9999-12-31')
select data.id,
       concat(substr(data.name, 1, 1), '*')                name,
       if(data.phone_num regexp '^(13[0-9]|14[01456879]|15[0-35-9]|16[2567]|17[0-8]|18[0-9]|19[0-35-9])d{8}$',
          concat(substr(data.phone_num, 1, 3), '*'), null) phone_num,
       if(data.email regexp '^[a-zA-Z0-9_-]+@[a-zA-Z0-9_-]+(.[a-zA-Z0-9_-]+)+$',
          concat('*@', split(data.email, '@')[1]), null)   email,
       data.user_level,
       data.birthday,
       data.gender,
       data.create_time,
       data.operate_time,
       '$do_date'                                        start_date,
       '9999-12-31'                                        end_date
from ${APP}.ods_user_info_inc
where dt = '$do_date'
  and type = 'bootstrap-insert';
"

dim_sku_full="
with
sku as
(
    select
        id,
        price,
        sku_name,
        sku_desc,
        weight,
        is_sale,
        spu_id,
        category3_id,
        tm_id,
        create_time
    from ${APP}.ods_sku_info_full
    where dt='$do_date'
),
spu as
(
    select
        id,
        spu_name
    from ${APP}.ods_spu_info_full
    where dt='$do_date'
),
c3 as
(
    select
        id,
        name,
        category2_id
    from ${APP}.ods_base_category3_full
    where dt='$do_date'
),
c2 as
(
    select
        id,
        name,
        category1_id
    from ${APP}.ods_base_category2_full
    where dt='$do_date'
),
c1 as
(
    select
        id,
        name
    from ${APP}.ods_base_category1_full
    where dt='$do_date'
),
tm as
(
    select
        id,
        tm_name
    from ${APP}.ods_base_trademark_full
    where dt='$do_date'
),
attr as
(
    select
        sku_id,
        collect_set(named_struct('attr_id',attr_id,'value_id',value_id,'attr_name',attr_name,'value_name',value_name)) attrs
    from ${APP}.ods_sku_attr_value_full
    where dt='$do_date'
    group by sku_id
),
sale_attr as
(
    select
        sku_id,
        collect_set(named_struct('sale_attr_id',sale_attr_id,'sale_attr_value_id',sale_attr_value_id,'sale_attr_name',sale_attr_name,'sale_attr_value_name',sale_attr_value_name)) sale_attrs
    from ${APP}.ods_sku_sale_attr_value_full
    where dt='$do_date'
    group by sku_id
)
insert overwrite table ${APP}.dim_sku_full partition(dt='$do_date')
select
    sku.id,
    sku.price,
    sku.sku_name,
    sku.sku_desc,
    sku.weight,
    sku.is_sale,
    sku.spu_id,
    spu.spu_name,
    sku.category3_id,
    c3.name,
    c3.category2_id,
    c2.name,
    c2.category1_id,
    c1.name,
    sku.tm_id,
    tm.tm_name,
    attr.attrs,
    sale_attr.sale_attrs,
    sku.create_time
from sku
left join spu on sku.spu_id=spu.id
left join c3 on sku.category3_id=c3.id
left join c2 on c3.category2_id=c2.id
left join c1 on c2.category1_id=c1.id
left join tm on sku.tm_id=tm.id
left join attr on sku.id=attr.sku_id
left join sale_attr on sku.id=sale_attr.sku_id;
"

dim_province_full="
insert overwrite table ${APP}.dim_province_full partition(dt='$do_date')
select
    province.id,
    province.name,
    province.area_code,
    province.iso_code,
    province.iso_3166_2,
    region_id,
    region_name
from
(
    select
        id,
        name,
        region_id,
        area_code,
        iso_code,
        iso_3166_2
    from ${APP}.ods_base_province_full
    where dt='$do_date'
)province
left join
(
    select
        id,
        region_name
    from ${APP}.ods_base_region_full
    where dt='$do_date'
)region
on province.region_id=region.id;
"

dim_coupon_full="
insert overwrite table ${APP}.dim_coupon_full partition(dt='$do_date')
select
    id,
    coupon_name,
    coupon_type,
    coupon_dic.dic_name,
    condition_amount,
    condition_num,
    activity_id,
    benefit_amount,
    benefit_discount,
    case coupon_type
        when '3201' then concat('满',condition_amount,'元减',benefit_amount,'元')
        when '3202' then concat('满',condition_num,'件打', benefit_discount,' 折')
        when '3203' then concat('减',benefit_amount,'元')
    end benefit_rule,
    create_time,
    range_type,
    range_dic.dic_name,
    limit_num,
    taken_count,
    start_time,
    end_time,
    operate_time,
    expire_time
from
(
    select
        id,
        coupon_name,
        coupon_type,
        condition_amount,
        condition_num,
        activity_id,
        benefit_amount,
        benefit_discount,
        create_time,
        range_type,
        limit_num,
        taken_count,
        start_time,
        end_time,
        operate_time,
        expire_time
    from ${APP}.ods_coupon_info_full
    where dt='$do_date'
)ci
left join
(
    select
        dic_code,
        dic_name
    from ${APP}.ods_base_dic_full
    where dt='$do_date'
    and parent_code='32'
)coupon_dic
on ci.coupon_type=coupon_dic.dic_code
left join
(
    select
        dic_code,
        dic_name
    from ${APP}.ods_base_dic_full
    where dt='$do_date'
    and parent_code='33'
)range_dic
on ci.range_type=range_dic.dic_code;
"

dim_activity_full="
insert overwrite table ${APP}.dim_activity_full partition(dt='$do_date')
select
    rule.id,
    info.id,
    activity_name,
    rule.activity_type,
    dic.dic_name,
    activity_desc,
    start_time,
    end_time,
    create_time,
    condition_amount,
    condition_num,
    benefit_amount,
    benefit_discount,
    case rule.activity_type
        when '3101' then concat('满',condition_amount,'元减',benefit_amount,'元')
        when '3102' then concat('满',condition_num,'件打', benefit_discount,' 折')
        when '3103' then concat('打', benefit_discount,'折')
    end benefit_rule,
    benefit_level
from
(
    select
        id,
        activity_id,
        activity_type,
        condition_amount,
        condition_num,
        benefit_amount,
        benefit_discount,
        benefit_level
    from ${APP}.ods_activity_rule_full
    where dt='$do_date'
)rule
left join
(
    select
        id,
        activity_name,
        activity_type,
        activity_desc,
        start_time,
        end_time,
        create_time
    from ${APP}.ods_activity_info_full
    where dt='$do_date'
)info
on rule.activity_id=info.id
left join
(
    select
        dic_code,
        dic_name
    from ${APP}.ods_base_dic_full
    where dt='$do_date'
    and parent_code='31'
)dic
on rule.activity_type=dic.dic_code;
"

dim_promotion_pos_full="
insert overwrite table ${APP}.dim_promotion_pos_full partition(dt='$do_date')
select
    id,           
    pos_location,
    pos_type,
    promotion_type,
    create_time,
    operate_time   
from ${APP}.ods_promotion_pos_full 
where dt='$do_date';
"

dim_promotion_refer_full="
insert overwrite table ${APP}.dim_promotion_refer_full partition(dt='$do_date')
select
    id, 
    refer_name,
    create_time,
    operate_time
from ${APP}.ods_promotion_refer_full 
where dt='$do_date';
"


case $1 in
"dim_user_zip")
    hive -e "$dim_user_zip"
;;
"dim_sku_full")
    hive -e "$dim_sku_full"
;;
"dim_province_full")
    hive -e "$dim_province_full"
;;
"dim_coupon_full")
    hive -e "$dim_coupon_full"
;;
"dim_activity_full")
    hive -e "$dim_activity_full"
    ;;
"dim_promotion_pos_full")
    hive -e "$dim_promotion_pos_full"
;;
"dim_promotion_refer_full")
    hive -e "$dim_promotion_refer_full"
;;

"all")
    hive -e "$dim_user_zip$dim_sku_full$dim_province_full$dim_coupon_full$dim_activity_full$dim_promotion_refer_full$dim_promotion_pos_full"
;;
esac

添加权限

chmod +x ods_to_dim_init.sh

执行脚本的命令

ods_to_dim_init.sh all 2022-06-08

2.每日增量脚本

cd /home/atguigu/bin
vim ods_to_dim.sh

添加下面的内容:

#!/bin/bash

APP=gmall

# 如果是输入的日期按照取输入日期;如果没输入日期取当前时间的前一天
if [ -n "$2" ] ;then
    do_date=$2
else 
    do_date=`date -d "-1 day" +%F`
fi

dim_user_zip="
set hive.exec.dynamic.partition.mode=nonstrict;
insert overwrite table ${APP}.dim_user_zip partition (dt)
select id,
       name,
       phone_num,
       email,
       user_level,
       birthday,
       gender,
       create_time,
       operate_time,
       start_date,
       if(rn = 2, date_sub('$do_date', 1), end_date)     end_date,
       if(rn = 1, '9999-12-31', date_sub('$do_date', 1)) dt
from (
         select id,
                name,
                phone_num,
                email,
                user_level,
                birthday,
                gender,
                create_time,
                operate_time,
                start_date,
                end_date,
                row_number() over (partition by id order by start_date desc) rn
         from (
                  select id,
                         name,
                         phone_num,
                         email,
                         user_level,
                         birthday,
                         gender,
                         create_time,
                         operate_time,
                         start_date,
                         end_date
                  from ${APP}.dim_user_zip
                  where dt = '9999-12-31'
                  union
                  select id,
                         concat(substr(name, 1, 1), '*')                name,
                         if(phone_num regexp
                            '^(13[0-9]|14[01456879]|15[0-35-9]|16[2567]|17[0-8]|18[0-9]|19[0-35-9])d{8}$',
                            concat(substr(phone_num, 1, 3), '*'), null) phone_num,
                         if(email regexp '^[a-zA-Z0-9_-]+@[a-zA-Z0-9_-]+(.[a-zA-Z0-9_-]+)+$',
                            concat('*@', split(email, '@')[1]), null)   email,
                         user_level,
                         birthday,
                         gender,
                         create_time,
                         operate_time,
                         '$do_date'                                   start_date,
                         '9999-12-31'                                   end_date
                  from (
                           select data.id,
                                  data.name,
                                  data.phone_num,
                                  data.email,
                                  data.user_level,
                                  data.birthday,
                                  data.gender,
                                  data.create_time,
                                  data.operate_time,
                                  row_number() over (partition by data.id order by ts desc) rn
                           from ${APP}.ods_user_info_inc
                           where dt = '$do_date'
                       ) t1
                  where rn = 1
              ) t2
     ) t3;
"

dim_sku_full="
with
sku as
(
    select
        id,
        price,
        sku_name,
        sku_desc,
        weight,
        is_sale,
        spu_id,
        category3_id,
        tm_id,
        create_time
    from ${APP}.ods_sku_info_full
    where dt='$do_date'
),
spu as
(
    select
        id,
        spu_name
    from ${APP}.ods_spu_info_full
    where dt='$do_date'
),
c3 as
(
    select
        id,
        name,
        category2_id
    from ${APP}.ods_base_category3_full
    where dt='$do_date'
),
c2 as
(
    select
        id,
        name,
        category1_id
    from ${APP}.ods_base_category2_full
    where dt='$do_date'
),
c1 as
(
    select
        id,
        name
    from ${APP}.ods_base_category1_full
    where dt='$do_date'
),
tm as
(
    select
        id,
        tm_name
    from ${APP}.ods_base_trademark_full
    where dt='$do_date'
),
attr as
(
    select
        sku_id,
        collect_set(named_struct('attr_id',attr_id,'value_id',value_id,'attr_name',attr_name,'value_name',value_name)) attrs
    from ${APP}.ods_sku_attr_value_full
    where dt='$do_date'
    group by sku_id
),
sale_attr as
(
    select
        sku_id,
        collect_set(named_struct('sale_attr_id',sale_attr_id,'sale_attr_value_id',sale_attr_value_id,'sale_attr_name',sale_attr_name,'sale_attr_value_name',sale_attr_value_name)) sale_attrs
    from ${APP}.ods_sku_sale_attr_value_full
    where dt='$do_date'
    group by sku_id
)
insert overwrite table ${APP}.dim_sku_full partition(dt='$do_date')
select
    sku.id,
    sku.price,
    sku.sku_name,
    sku.sku_desc,
    sku.weight,
    sku.is_sale,
    sku.spu_id,
    spu.spu_name,
    sku.category3_id,
    c3.name,
    c3.category2_id,
    c2.name,
    c2.category1_id,
    c1.name,
    sku.tm_id,
    tm.tm_name,
    attr.attrs,
    sale_attr.sale_attrs,
    sku.create_time
from sku
left join spu on sku.spu_id=spu.id
left join c3 on sku.category3_id=c3.id
left join c2 on c3.category2_id=c2.id
left join c1 on c2.category1_id=c1.id
left join tm on sku.tm_id=tm.id
left join attr on sku.id=attr.sku_id
left join sale_attr on sku.id=sale_attr.sku_id;
"

dim_province_full="
insert overwrite table ${APP}.dim_province_full partition(dt='$do_date')
select
    province.id,
    province.name,
    province.area_code,
    province.iso_code,
    province.iso_3166_2,
    region_id,
    region_name
from
(
    select
        id,
        name,
        region_id,
        area_code,
        iso_code,
        iso_3166_2
    from ${APP}.ods_base_province_full
    where dt='$do_date'
)province
left join
(
    select
        id,
        region_name
    from ${APP}.ods_base_region_full
    where dt='$do_date'
)region
on province.region_id=region.id;
"

dim_coupon_full="
insert overwrite table ${APP}.dim_coupon_full partition(dt='$do_date')
select
    id,
    coupon_name,
    coupon_type,
    coupon_dic.dic_name,
    condition_amount,
    condition_num,
    activity_id,
    benefit_amount,
    benefit_discount,
    case coupon_type
        when '3201' then concat('满',condition_amount,'元减',benefit_amount,'元')
        when '3202' then concat('满',condition_num,'件打', benefit_discount,' 折')
        when '3203' then concat('减',benefit_amount,'元')
    end benefit_rule,
    create_time,
    range_type,
    range_dic.dic_name,
    limit_num,
    taken_count,
    start_time,
    end_time,
    operate_time,
    expire_time
from
(
    select
        id,
        coupon_name,
        coupon_type,
        condition_amount,
        condition_num,
        activity_id,
        benefit_amount,
        benefit_discount,
        create_time,
        range_type,
        limit_num,
        taken_count,
        start_time,
        end_time,
        operate_time,
        expire_time
    from ${APP}.ods_coupon_info_full
    where dt='$do_date'
)ci
left join
(
    select
        dic_code,
        dic_name
    from ${APP}.ods_base_dic_full
    where dt='$do_date'
    and parent_code='32'
)coupon_dic
on ci.coupon_type=coupon_dic.dic_code
left join
(
    select
        dic_code,
        dic_name
    from ${APP}.ods_base_dic_full
    where dt='$do_date'
    and parent_code='33'
)range_dic
on ci.range_type=range_dic.dic_code;
"

dim_activity_full="
insert overwrite table ${APP}.dim_activity_full partition(dt='$do_date')
select
    rule.id,
    info.id,
    activity_name,
    rule.activity_type,
    dic.dic_name,
    activity_desc,
    start_time,
    end_time,
    create_time,
    condition_amount,
    condition_num,
    benefit_amount,
    benefit_discount,
    case rule.activity_type
        when '3101' then concat('满',condition_amount,'元减',benefit_amount,'元')
        when '3102' then concat('满',condition_num,'件打', benefit_discount,' 折')
        when '3103' then concat('打', benefit_discount,'折')
    end benefit_rule,
    benefit_level
from
(
    select
        id,
        activity_id,
        activity_type,
        condition_amount,
        condition_num,
        benefit_amount,
        benefit_discount,
        benefit_level
    from ${APP}.ods_activity_rule_full
    where dt='$do_date'
)rule
left join
(
    select
        id,
        activity_name,
        activity_type,
        activity_desc,
        start_time,
        end_time,
        create_time
    from ${APP}.ods_activity_info_full
    where dt='$do_date'
)info
on rule.activity_id=info.id
left join
(
    select
        dic_code,
        dic_name
    from ${APP}.ods_base_dic_full
    where dt='$do_date'
    and parent_code='31'
)dic
on rule.activity_type=dic.dic_code;
"


dim_promotion_pos_full="
insert overwrite table ${APP}.dim_promotion_pos_full partition(dt='$do_date')
select
    id,            
    pos_location,
    pos_type,
    promotion_type,
    create_time,
    operate_time
from ${APP}.ods_promotion_pos_full 
where dt='$do_date';
"

dim_promotion_refer_full="
insert overwrite table ${APP}.dim_promotion_refer_full partition(dt='$do_date')
select
    id, 
    refer_name,
    create_time,
    operate_time
from ${APP}.ods_promotion_refer_full 
where dt='$do_date';
"


case $1 in
"dim_user_zip")
    hive -e "$dim_user_zip"
;;
"dim_sku_full")
    hive -e "$dim_sku_full"
;;
"dim_province_full")
    hive -e "$dim_province_full"
;;
"dim_coupon_full")
    hive -e "$dim_coupon_full"
;;
"dim_activity_full")
    hive -e "$dim_activity_full"
;;
"dim_promotion_pos_full")
    hive -e "$dim_promotion_pos_full"
;;
"dim_promotion_refer_full")
    hive -e "$dim_promotion_refer_full"
;;

"all")
    hive -e "$dim_user_zip$dim_sku_full$dim_province_full$dim_coupon_full$dim_activity_full$dim_promotion_refer_full$dim_promotion_pos_full"
;;
esac

添加权限

chmod +x ods_to_dim.sh

脚本执行的命令(以6月9号为例)

ods_to_dim.sh all 2022-06-09

本文地址:https://www.yitenyun.com/3013.html

搜索文章

Tags

#服务器 #python #pip #conda #人工智能 #微信 #ios面试 #ios弱网 #断点续传 #ios开发 #objective-c #ios #ios缓存 #远程工作 #Trae #IDE #AI 原生集成开发环境 #Trae AI 香港站群服务器 多IP服务器 香港站群 站群服务器 #kubernetes #笔记 #平面 #容器 #linux #学习方法 #运维 #log4j #ollama #飞牛nas #fnos #kylin #docker #arm #科技 #深度学习 #自然语言处理 #神经网络 #hadoop #hbase #hive #zookeeper #spark #kafka #flink #低代码 #爬虫 #音视频 #银河麒麟高级服务器操作系统安装 #银河麒麟高级服务器V11配置 #设置基础软件仓库时出错 #银河麒高级服务器系统的实操教程 #生产级部署银河麒麟服务系统教程 #Linux系统的快速上手教程 #AI编程 #学习 #飞书 #语言模型 #大模型 #ai #ai大模型 #agent #华为云 #部署上线 #动静分离 #Nginx #新人首发 #fastapi #html #css #大数据 #职场和发展 #程序员创富 #ARM服务器 # GLM-4.6V # 多模态推理 #PyTorch #模型训练 #星图GPU #分阶段策略 #模型协议 #ide #java #开发语言 #前端 #javascript #架构 #MobaXterm #ubuntu #ssh #经验分享 #安卓 #langchain #数据库 #harmonyos #鸿蒙PC #windows #物联网 #websocket #nginx #开源 #C++ #Reactor #进程控制 #驱动开发 #c++ #自动化 #ansible #云计算 #github #git #tcp/ip #网络 #qt #aws #unity #c# #游戏引擎 #私有化部署 #node.js #区块链 #测试用例 #生活 #pytorch #word #umeditor粘贴word #ueditor粘贴word #ueditor复制word #ueditor上传word图片 #gemini #gemini国内访问 #gemini api #gemini中转搭建 #Cloudflare #cpolar #fabric #postgresql #openHiTLS #TLCP #DTLCP #密码学 #商用密码算法 #android #腾讯云 #Conda # 私有索引 # 包管理 #大模型学习 #AI大模型 #大模型教程 #大模型入门 #vue上传解决方案 #vue断点续传 #vue分片上传下载 #vue分块上传下载 #jar #数信院生信服务器 #Rstudio #生信入门 #生信云服务器 #sql #AIGC #agi #内网穿透 #mysql #RTP over RTSP #RTP over TCP #RTSP服务器 #RTP #TCP发送RTP #云原生 #iventoy #VmWare #OpenEuler #风控模型 #决策盲区 #算法 #牛客周赛 #dify #ci/cd #jenkins #gitlab #pycharm #Ansible # 自动化部署 # VibeThinker #文心一言 #AI智能体 #Harbor #centos #svn #后端 #机器学习 #矩阵 #线性代数 #AI运算 #向量 #flutter #vscode #缓存 #mobaxterm #计算机视觉 #硬件工程 #http #项目 #高并发 #spring cloud #spring #vue.js #json #serverless #阿里云 #diskinfo # TensorFlow # 磁盘健康 #儿童书籍 #儿童诗歌 #童话故事 #经典好书 #儿童文学 #好书推荐 #经典文学作品 #microsoft #鸿蒙 #mcp #mcp server #AI实战 #边缘计算 #重构 #ecmascript #elementui #开源软件 #FTP服务器 #流程图 #论文阅读 #信息可视化 #c语言 #FaceFusion # Token调度 # 显存优化 #数学建模 #设备驱动 #芯片资料 #网卡 #java-ee #shell #CPU利用率 #分布式 #华为 #iBMC #UltraISO #性能优化 #2026年美赛C题代码 #2026年美赛 #spring boot #php #java大文件上传 #java大文件秒传 #java大文件上传下载 #java文件传输解决方案 #超算服务器 #算力 #高性能计算 #仿真分析工作站 #springboot #prometheus #企业开发 #ERP #项目实践 #.NET开发 #C#编程 #编程与数学 #内存治理 #django #jmeter #功能测试 #软件测试 #自动化测试 #Ubuntu服务器 #硬盘扩容 #命令行操作 #VMware #stm32 #多个客户端访问 #IO多路复用 #回显服务器 #TCP相关API #mvp #个人开发 #设计模式 #llama #opencv #CFD #mongodb #数据结构 #mcu #MCP #MCP服务器 #进程 #web安全 #安全 #蓝桥杯 #正则 #正则表达式 #信息与通信 #时序数据库 #程序人生 #科研 #博士 #游戏 #产品经理 #ui #团队开发 #墨刀 #figma #Windows 更新 #搜索引擎 #导航网 #select #PyCharm # 远程调试 # YOLOFuse #大语言模型 #长文本处理 #GLM-4 #Triton推理 #嵌入式 #Dell #PowerEdge620 #内存 #硬盘 #RAID5 #鸭科夫 #逃离鸭科夫 #鸭科夫联机 #鸭科夫异地联机 #开服 #毕业设计 #系统架构 #rocketmq #Linux #TCP #线程 #线程池 #RAGFlow #DeepSeek-R1 #powerpoint #Com #web #webdav #chatgpt #DeepSeek #AI #DS随心转 #flask #FL Studio #FLStudio #FL Studio2025 #FL Studio2026 #FL Studio25 #FL Studio26 #水果软件 #vim #gcc #yum #redis #网络协议 #lvs #负载均衡 #uni-app #小程序 #notepad++ #es安装 #jetty #scrapy #课程设计 #jvm #服务器繁忙 #SSH # ProxyJump # 跳板机 #哈希算法 #散列表 #dreamweaver #HCIA-Datacom #H12-811 #题库 #最新题库 #计算机网络 #线性回归 #transformer #AI写作 #Agent #程序员 #ffmpeg #udp #酒店客房管理系统 #毕设 #论文 #学习笔记 #jdk #https #leetcode #wsl #L2C #勒让德到切比雪夫 #ssl #深度优先 #DFS #钉钉 #机器人 #企业微信 #Android #Bluedroid #LLM #3d #arm开发 #嵌入式硬件 #堡垒机 #安恒明御堡垒机 #windterm #PowerBI #企业 #自动驾驶 #golang #能源 #servlet #todesk #京东云 #阻塞队列 #生产者消费者模型 #服务器崩坏原因 #SSM 框架 #孕期健康 #产品服务推荐 #推荐系统 #用户交互 #数据集 #vllm #Streamlit #Qwen #本地部署 #AI聊天机器人 #零售 #AI产品经理 #大模型开发 #mmap #nio #语音识别 #rabbitmq #protobuf #我的世界 #游戏私服 #云服务器 #网络安全 #全能视频处理软件 #视频裁剪工具 #视频合并工具 #视频压缩工具 #视频字幕提取 #视频处理工具 #YOLO #逻辑回归 #电脑 #Canal #信号处理 #目标跟踪 #AB包 #社科数据 #数据分析 #数据挖掘 #数据统计 #经管数据 #Tracker 服务器 #响应最快 #torrent 下载 #2026年 #Aria2 可用 #迅雷可用 #BT工具通用 #sqlserver #压枪 #DisM++ # 系统维护 #蓝耘智算 #vue3 #天地图 #403 Forbidden #天地图403错误 #服务器403问题 #天地图API #部署报错 #autosar #数据仓库 #AI论文写作工具 #学术论文创作 #论文效率提升 #MBA论文写作 #claude #操作系统 #cnn #智能手机 #gitee #pjsip #svm #amdgpu #kfd #ROCm #求职招聘 #面试 #everything #数模美赛 #matlab #就业 #openclaw #whisper #守护进程 #复用 #screen #分类 #单片机 #abtest #iphone #聚类 #树莓派4b安装系统 #adb #架构师 #软考 #系统架构师 #TURN # WebRTC # HiChatBox #AI大模型应用开发 #ESXi #ModelEngine #银河麒麟 #系统升级 #信创 #国产化 #贪心算法 #pdf #gpu算力 #paddlepaddle #其他 #金融 #金融投资Agent #支持向量机 #启发式算法 #debian #oracle #CISSP #CISSP考点 #信息安全 #CISSP哪里考 #公众号:厦门微思网络 #+微信号:xmweisi #排序算法 #插入排序 #Chat平台 #ARM架构 #考研 #软件工程 #1024程序员节 #GB/T4857 #GB/T4857.17 #GB/T4857测试 #HeyGem # 局域网访问 # 批量处理 #claude code #codex #code cli #ccusage #Ascend #MindIE #OBC #银河麒麟操作系统 #openssh #华为交换机 #信创终端 #openresty #lua #twitter #电气工程 #C# #PLC #ssm #elasticsearch #版本控制 #Git入门 #开发工具 #代码托管 #ProCAST2025 #ProCast #脱模 #顶出 #应力计算 #铸造仿真 #变形计算 #laravel #里氏替换原则 #幼儿园 #园长 #幼教 #SSH Agent Forwarding # PyTorch # 容器化 #n8n #Keycloak #Quarkus #AI编程需求分析 #推荐算法 #sizeof和strlen区别 #sizeof #strlen #计算数据类型字节数 #计算字符串长度 #googlecloud #若依 #quartz #框架 #需求分析 #scala #测试工具 #压力测试 #七年级上册数学 #有理数 #有理数的加法法则 #绝对值 #流量运营 #用户运营 # 服务器IP访问 # 端口映射 #prompt #react.js #react native #epoll #高级IO #文生视频 #CogVideoX #AI部署 #环境搭建 #pandas #matplotlib #mamba #凤希AI伴侣 #tomcat #firefox #我的世界服务器搭建 #minecraft #rust #双指针 #机器视觉 #6D位姿 #流量监控 #硬件 #LoRA # RTX 3090 # lora-scripts #fiddler #ddos #OCR #文字检测 #windbg分析蓝屏教程 #fastmcp #串口服务器 #Modbus #IFix #MC #数组 #长文本理解 #glm-4 #推理部署 #macos #几何学 #拓扑学 #链表 #链表的销毁 #链表的排序 #链表倒置 #判断链表是否有环 #电商 #anaconda #虚拟环境 #fpga开发 #LVDS #高速ADC #DDR #eBPF #web3 #grafana #Modbus-TCP #人脸识别 #人脸核身 #活体检测 #身份认证与人脸对比 #H5 #微信公众号 #ai编程 #ICPC #azure #asp.net大文件上传 #asp.net大文件上传下载 #asp.net大文件上传源码 #ASP.NET断点续传 #asp.net上传文件夹 #dubbo #测试流程 #金融项目实战 #P2P #编辑器 #ISP Pipeline #行缓冲 #智慧校园解决方案 #智慧校园一体化平台 #智慧校园选型 #智慧校园采购 #智慧校园软件 #智慧校园专项资金 #智慧校园定制开发 #LangGraph #模型上下文协议 #MultiServerMCPC #load_mcp_tools #load_mcp_prompt #新浪微博 #前端框架 #微信小程序 #ida #webrtc #结构体 #glibc #中间件 #ping通服务器 #读不了内网数据库 #bug菌问答团队 #研发管理 #禅道 #禅道云端部署 #数码相机 #ONLYOFFICE #MCP 服务器 #论文笔记 #zabbix #游戏美术 #技术美术 #游戏策划 #游戏程序 #用户体验 #HBA卡 #RAID卡 #STUN # TURN # NAT穿透 #RAID #RAID技术 #磁盘 #存储 #Coze工作流 #AI Agent指挥官 #多智能体系统 #VS Code调试配置 #无人机 #Deepoc #具身模型 #开发板 #未来 #tdengine #制造 #涛思数据 #测试覆盖率 #单元测试 #可用性测试 #unity3d #服务器框架 #Fantasy #asp.net #Proxmox VE #虚拟化 #改行学it #llm #lstm #智慧城市 #海外短剧 #海外短剧app开发 #海外短剧系统开发 #短剧APP #短剧APP开发 #短剧系统开发 #海外短剧项目 #pytest #rtmp #银河麒麟部署 #银河麒麟部署文档 #银河麒麟linux #银河麒麟linux部署教程 #visual studio code #Cpolar #国庆假期 #服务器告警 #GPU服务器 #8U #硬件架构 #工业级串口服务器 #串口转以太网 #串口设备联网通讯模块 #串口服务器选型 #Node.js #漏洞检测 #CVE-2025-27210 #ROS #跨域 #发布上线后跨域报错 #请求接口跨域问题解决 #跨域请求代理配置 #request浏览器跨域 #生信 #FRP #UDP的API使用 #游戏机 #JumpServer #journalctl #远程连接 #振镜 #振镜焊接 #wordpress #雨云 #LobeChat #vLLM #GPU加速 #selenium #RAG #全链路优化 #实战教程 #xeon #UDP套接字编程 #UDP协议 #网络测试 #SRS #流媒体 #直播 #SSE #SSH反向隧道 # Miniconda # Jupyter远程访问 #.net #homelab #Lattepanda #Jellyfin #Plex #Emby #Kodi #蓝牙 #LE Audio #BAP #TensorRT # Triton # 推理优化 #Nacos #微服务 #gpu #nvcc #cuda #nvidia #三种参数 #参数的校验 #fastAPI #目标检测 #YOLO26 #YOLO11 #计算机 #连锁药店 #连锁店 #xlwings #Excel #建筑缺陷 #红外 #漏洞 #智能路由器 # 公钥认证 #Karalon #AI Test #命令模式 #YOLOv8 # 目标检测 # Docker镜像 #clickhouse #Ubuntu #Steam #饥荒联机版 #代理 #零代码平台 #AI开发 #北京百思可瑞教育 #百思可瑞教育 #北京百思教育 #visual studio #CNAS #CMA #程序文件 #图像处理 #yolo #监控 #自动化运维 #敏捷流程 #esp32教程 #行为模式分析 #数据 #应用层 #跨领域 #敏感信息 #apache #SA-PEKS # 关键词猜测攻击 # 盲签名 # 限速机制 #模版 #函数 #类 #笔试 #LabVIEW知识 #LabVIEW程序 #labview #LabVIEW功能 #risc-v #ipv6 #WEB #CMake #Make #C/C++ #Python #ms-swift # 一锤定音 # 大模型微调 #deepseek #高品质会员管理系统 #收银系统 #同城配送 #最好用的电商系统 #最好用的系统 #推荐的前十系统 #JAVA PHP 小程序 #SSH公钥认证 # 安全加固 #排序 #Fun-ASR # 语音识别 # WebUI # 高并发部署 #密码 #cpp #vps #CUDA #Docker #echarts #Rust #软件 #本地生活 #电商系统 #商城 ##程序员和算法的浪漫 #SMP(软件制作平台) #EOM(企业经营模型) #应用系统 #Playbook #AI服务器 #AI助手 #企业微信集成 #轻量大模型 #simulink #list #aiohttp #asyncio #异步 #学术写作辅助 #论文创作效率提升 #AI写论文实测 #Qwen3-14B # 大模型部署 # 私有化AI #NAS #飞牛NAS #NVR #EasyNVR #项目申报系统 #项目申报管理 #项目申报 #企业项目申报 #wpf #JAVA #Java #ue4 #ue5 #DedicatedServer #独立服务器 #专用服务器 #vp9 #AutoDL #安全架构 #screen 命令 #运维开发 #opc ua #opc #语义搜索 #嵌入模型 #Qwen3 #AI推理 # GLM-TTS # 数据安全 #Shiro #反序列化漏洞 #CVE-2016-4437 #支付 #指针 #React安全 #漏洞分析 #Next.js #python学习路线 #python基础 #python进阶 #python标准库 #Gunicorn #WSGI #Flask #并发模型 #容器化 #性能调优 #数据结构与算法 #联机教程 #局域网联机 #局域网联机教程 #局域网游戏 #EMC存储 #存储维护 #NetApp存储 #职场发展 #embedding #vuejs #运营 #汽车 #源代码管理 #ip #ceph #高仿永硕E盘的个人网盘系统源码 #SSH别名 # CUDA #maven #typescript #npm #VPS #搭建 #土地承包延包 #领码SPARK #aPaaS+iPaaS #数字化转型 #智能审核 #档案数字化 #SAP #ebs #metaerp #oracle ebs #SSH跳转 #RustDesk # IndexTTS # GPU集群 #框架搭建 #Moltbot #Anaconda配置云虚拟环境 #2026AI元年 #年度趋势 #国产PLM #瑞华丽PLM #瑞华丽 #PLM #C语言 #vivado license # 远程访问 # 服务器IP配置 #捷配 #pcb工艺 #MS #Materials #SMTP # 内容安全 # Qwen3Guard #X11转发 #Miniconda #可信计算技术 #可撤销IBE #服务器辅助 #私钥更新 #安全性证明 #双线性Diffie-Hellman #区间dp #二进制枚举 #图论 #winscp #智能体 #多线程 #性能调优策略 #双锁实现细节 #动态分配节点内存 #markdown #建站 #跳槽 #业界资讯 #google #search # 双因素认证 # AI翻译机 # 实时翻译 #创业创新 #5G #平板 #交通物流 #智能硬件 #IO #插件 #策略模式 #r-tree #K8s #镜像 #集群自动化 #心理健康服务平台 #心理健康系统 #心理服务平台 #心理健康小程序 # IndexTTS 2.0 # 远程运维 #cursor #性能测试 #LoadRunner #进程创建与终止 #bytebase #VibeVoice # 语音合成 #TFTP #客户端 #spine #dynadot #域名 #工厂模式 #bootstrap #交互 #chrome #tensorflow #wps #dba #IndexTTS2 # 阿里云安骑士 # 木马查杀 #NPU #CANN #Moltbook #Clawdbot #IndexTTS 2.0 #本地化部署 #文件IO #输入输出流 #log #tcpdump #PyTorch 特性 #动态计算图 #张量(Tensor) #自动求导Autograd #GPU 加速 #生态系统与社区支持 #与其他框架的对比 #cascadeur #设计师 #车辆排放 #SEO优化 #浏览器自动化 #python #Spring AI #STDIO协议 #Streamable-HTTP #McpTool注解 #服务器能力 #vue #paddleocr #大剑师 #nodejs面试题 #SSH免密登录 #集成测试 #静脉曲张 #腿部健康 #spring native #智能一卡通 #门禁一卡通 #梯控一卡通 #电梯一卡通 #消费一卡通 #一卡通 #考勤一卡通 #远程访问 #远程办公 #飞网 #安全高效 #配置简单 #远程桌面 #远程控制 #pencil #pencil.dev #设计 #Anything-LLM #IDC服务器 #工具集 #bash #逆向工程 #ngrok #sqlite #RK3576 #瑞芯微 #硬件设计 #css3 #社交智慧 #职场生存 #系统思维 #身体管理 #商务宴请 #拒绝油腻 #清醒日常 #chat #Triton #iot #智能家居 #p2p #Spring #Spring Boot #RPA #影刀RPA #AI办公 #intellij-idea #database #idea #rdp #galeweather.cn #高精度天气预报数据 #光伏功率预测 #风电功率预测 #高精度气象 #海外服务器安装宝塔面板 #翻译 #开源工具 #910B #SSH保活 #远程开发 #mybatis #openlayers #bmap #tile #server #贴图 #材质 #爱心代码 #表白代码 #爱心 #tkinter #情人节表白代码 #媒体 #测评 # GLM-4.6V-Flash-WEB # 显卡驱动备份 #jupyter #虚拟机 #简单数论 #埃氏筛法 #openEuler #Hadoop #WinSCP 下载安装教程 #SFTP #FTP工具 #服务器文件传输 #DIY机器人工房 #JT/T808 #车联网 #车载终端 #模拟器 #仿真器 #开发测试 #个人博客 #mapreduce #AI赋能盾构隧道巡检 #开启基建安全新篇章 #以注意力为核心 #YOLOv12 #AI隧道盾构场景 #盾构管壁缺陷病害异常检测预警 #隧道病害缺陷检测 #nacos #银河麒麟aarch64 #uvicorn #uvloop #asgi #event #yolov12 #研究生life #nas #音乐分类 #音频分析 #ViT模型 #Gradio应用 #鼠大侠网络验证系统源码 #powerbi #go #状态模式 #嵌入式编译 #ccache #distcc #信令服务器 #Janus #MediaSoup #群晖 #音乐 #Deepseek #gpt-3 #ARM64 # DDColor # ComfyUI #Jetty # CosyVoice3 # 嵌入式服务器 #puppeteer #鸿蒙系统 #系统安全 #车载系统 #企业架构治理 #电力企业IT架构 #IT架构设计 #excel #GLM-4.6V-Flash-WEB # AI视觉 # 本地部署 #Fluentd #Sonic #日志采集 #restful #ajax #转行 #Claude #视频去字幕 #flume #外卖配送 #处理器模块 #现货库存 #价格优惠 #PM864AK01 #3BSE018161R1 #控制器模块 #空间计算 #原型模式 #迁移重构 #数据安全 #代码迁移 #UDP #榛樿鍒嗙被 #mariadb #gateway #Comate #遛狗 #bug #网络编程 #I/O模型 #并发 #水平触发、边缘触发 #多路复用 #文件管理 #文件服务器 #国产开源制品管理工具 #Hadess #一文上手 #kong #Kong Audio #Kong Audio3 #KongAudio3 #空音3 #空音 #中国民乐 #范式 #实在Agent #SSH复用 # 远程开发 #CPU #监测 #ET模式 #非阻塞 #高并发服务器 #C++ UA Server #SDK #Windows #跨平台开发 #eclipse #arm64 #OPCUA #注入漏洞 #OSS #图像识别 #MOXA #GATT服务器 #蓝牙低功耗 #分库分表 #垂直分库 #水平分表 #雪花算法 #分布式ID #跨库查询 #UOS #海光K100 #统信 #工程实践 #KMS激活 # 硬件配置 #思维模型 #认知框架 #认知 #算力一体机 #ai算力服务器 #gpt #API #taro #青少年编程 #考试系统 #在线考试 #培训考试 #考试练习 #safari #部署 #昇腾300I DUO #docker-compose #vrrp #脑裂 #keepalived主备 #高可用主备都持有VIP #coffeescript #软件需求 #CSDN #寄存器 #le audio #低功耗音频 #通信 #连接 #知识库 #vnstat #c++20 # 远程连接 #tornado #webpack #H3C #vmware #挖漏洞 #渗透测试 #黑客技术 #攻击溯源 #编程 #攻防演练 #Java web #红队 #blender #warp #reactjs #Aluminium #Google #学工管理系统 #学工一体化平台 #学工软件二次开发 #学工平台定制开发 #学工系统服务商 #学工系统源头厂家 #智慧校园学工系统 #材料工程 #智能电视 #东方仙盟 #Go并发 #高并发架构 #Goroutine #系统设计 #Dify #鲲鹏 #net core #kestrel #web-server #asp.net-core #API限流 # 频率限制 # 令牌桶算法 #TTS私有化 # 音色克隆 #FASTMCP #因果学习 #黑群晖 #无U盘 #纯小白 #网络攻击模型 #cocoa #tcp/ip #网络 #GB28181 #SIP信令 #SpringBoot #视频监控 #SSH跳板机 # Python3.11 #WT-2026-0001 #QVD-2026-4572 #smartermail #Puppet # IndexTTS2 # TTS #蓝湖 #Axure原型发布 #视频 #gitea #三维重建 #高斯溅射 #Tetrazine-Acid #1380500-92-4 #postman #UEFI #BIOS #Legacy BIOS #产品运营 #1panel #门禁 #梯控 #智能梯控 #汇编 #turn #网安应急响应 #微PE # GLM # 服务连通性 #说话人验证 #声纹识别 #CAM++ #云开发 #KMS 激活 #AI智能棋盘 #Rock Pi S #ambari #MC群组服务器 #阳台种菜 #园艺手扎 #Gemini #Nano Banana Pro #muduo库 #CS2 #debian13 #uv #uvx #uv pip #npx #Ruff #BoringSSL # 高并发 #数据恢复 #视频恢复 #视频修复 #RAID5恢复 #流媒体服务器恢复 #claude-code #软件开发 #PTP_1588 #gPTP #农产品物流管理 #物流管理系统 #农产品物流系统 #农产品物流 #xss #unix #k8s #Tokio #昇腾 #ICE #信创国产化 #达梦数据库 #未加引号服务路径 # ARM服务器 # 鲲鹏 #服务器开启 TLS v1.2 #IISCrypto 使用教程 #TLS 协议配置 #IIS 安全设置 #服务器运维工具 #http头信息 #VSCode # SSH #创业管理 #财务管理 #团队协作 #创始人必修课 #数字化决策 #经营管理 #TCP服务器 #开发实战 #RSO #机器人操作系统 #mtgsig #美团医药 #美团医药mtgsig #美团医药mtgsig1.2 #MQTT协议 #网站 #截图工具 #批量处理图片 #图片格式转换 #图片裁剪 #卷积神经网络 #CVE-2025-68143 #CVE-2025-68144 #CVE-2025-68145 #dash #Socket #套接字 #I/O多路复用 #字节序 #进程等待 #wait #waitpid #树莓派 #温湿度监控 #WhatsApp通知 #IoT #MySQL # 离线AI #html5 #weston #x11 #x11显示服务器 #文件上传漏洞 #证书 #Kylin-Server #国产操作系统 #服务器安装 #Android16 #音频性能实战 #音频进阶 #短剧 #短剧小程序 #短剧系统 #微剧 #hibernate #nosql #结构与算法 #集成学习 # 数字人系统 # 远程部署 #域名注册 #新媒体运营 #网站建设 #国外域名 #TLS协议 #HTTPS #漏洞修复 #运维安全 #DDD #tdd #easyui #大学生 #大作业 #JNI #扩展屏应用开发 #android runtime #CTF # GPU服务器 # tmux #sentinel #聊天小程序 #rustdesk #连接数据库报错 #esp32 #mosquito #DNS #Discord机器人 #云部署 #程序那些事 #服务器解析漏洞 #nodejs #云服务器选购 #Saas #智能体从0到1 #新手入门 #NFC #智能公交 #服务器计费 #FP-增长 #outlook #错误代码2603 #无网络连接 #2603 #TRO #TRO侵权 #TRO和解 #运维工具 #效率神器 #办公技巧 #自动化工具 #Windows技巧 #打工人必备 #YOLOFuse # Base64编码 # 多模态检测 #SQL调优 #EXPLAIN #慢查询日志 #分布式架构 #后端开发 #ipmitool #BMC # 黑屏模式 # TTS服务器 #C #esb接口 #走处理类报异常 #领域驱动 #N8N #移动端h5网页 #调用浏览器摄像头并拍照 #开启摄像头权限 #拍照后查看与上传服务器端 #摄像头黑屏打不开问题 #SPA #单页应用 #具身智能 #web3.py #kmeans #练习 #基础练习 #循环 #九九乘法表 #计算机实现 #数字孪生 #三维可视化 # Qwen3Guard-Gen-8B #smtp #smtp服务器 #PHP #intellij idea #入侵 #日志排查 #晶振 #WinDbg #Windows调试 #内存转储分析 #麒麟OS #随机森林 #swagger #运维 #AI视频创作系统 #AI视频创作 #AI创作系统 #AI视频生成 #AI工具 #AI创作工具 #fs7TF #夏天云 #夏天云数据 #hdfs #华为od #华为od机试 #华为od机考 #华为od最新上机考试题库 #华为OD题库 #华为OD机试双机位C卷 #od机考题库 #AI+ #coze #AI入门 #AI赋能 #计组 #数电 #cosmic # 大模型 # 模型训练 #pve #CLI #JavaScript #langgraph.json #Python3.11 #知识图谱 #npu #React #Next #CVE-2025-55182 #RSC #raid #raid阵列 #处理器 #clawdbot #上下文工程 #langgraph #意图识别 #ansys #ansys问题解决办法 #单例模式 #快递盒检测检测系统 #bigtop #hdp #hue #kerberos #远程软件 #QQbot #QQ #HarmonyOS #数据采集 #浏览器指纹 #vertx #vert.x #vertx4 #runOnContext #视觉检测 #分布式数据库 #集中式数据库 #业务需求 #选型误 #ESP32 #传感器 #MicroPython # Connection refused #WRF #WRFDA #欧拉 #百度 #teamviewer #儿童AI #图像生成 #gRPC #注册中心 #异步编程 #系统编程 #Pin #http服务器 #AutoDL使用教程 #AI大模型训练 #linux常用命令 #PaddleOCR训练 #edge #迭代器模式 #观察者模式 #机器人学习 #CosyVoice3 # IP配置 # 0.0.0.0 #Apple AI #Apple 人工智能 #FoundationModel #Summarize #SwiftUI #Syslog #系统日志 #日志分析 #日志监控 #生产服务器问题查询 #日志过滤 #网络配置实战 #Web/FTP 服务访问 #计算机网络实验 #外网访问内网服务器 #Cisco 路由器配置 #静态端口映射 #网络运维 # 水冷服务器 # 风冷服务器 #防火墙 #elk #VoxCPM-1.5-TTS # 云端GPU # PyCharm宕机 #Socket网络编程 #工作 # 服务器配置 # GPU #AI生成 # outputs目录 # 自动化 #stl #IIS Crypto #健康医疗 #教育电商 #libosinfo #milvus #web server #请求处理流程 #esp32 arduino #HistoryServer #Spark #YARN #jobhistory #勒索病毒 #勒索软件 #加密算法 #.bixi勒索病毒 #数据加密 #sglang #CA证书 #ZooKeeper #ZooKeeper面试题 #面试宝典 #深入解析 #大模型部署 #mindie #大模型推理 #ComfyUI # 推理服务器 #LangFlow # 轻量化镜像 # 边缘计算 #agentic bi #论文复现 #sql注入 #opc模拟服务器 #内存接口 # 澜起科技 # 服务器主板 #模拟退火算法 #Host #SSRF #知识 #科普 # 批量部署 #copilot #星际航行 # 键鼠锁定 #wireshark #x86_64 #数字人系统 #华为od机考真题 #华为od机试真题 #华为OD上机考试真题 #华为OD上机考试双机位C卷 #华为ODFLASH坏块监测系统 # ms-swift #windows11 #系统修复 #osg #服务器线程 # SSL通信 # 动态结构体 #娱乐 #计算机毕业设计 #程序定制 #毕设代做 #课设 #政务 #文件传输 #电脑文件传输 #电脑传输文件 #电脑怎么传输文件到另一台电脑 #电脑传输文件到另一台电脑 #语音生成 #TTS #性能 #优化 #RAM #rtsp #转发 #学术生涯规划 #CCF目录 #基金申请 #职称评定 #论文发表 #科研评价 #顶会顶刊 #个人助理 #数字员工 #cocos2d #图形渲染 #AI技术 #KMS #slmgr #IT #技术 #IntelliJ IDEA #宝塔面板部署RustDesk #RustDesk远程控制手机 #手机远程控制 #neo4j #NoSQL #SQL #Llama-Factory # 大模型推理 #可再生能源 #绿色算力 #风电 #节日 #ESP32编译服务器 #Ping #DNS域名解析 #Kuikly #openharmony #麦克风权限 #访问麦克风并录制音频 #麦克风录制音频后在线播放 #用户拒绝访问麦克风权限怎么办 #uniapp 安卓 苹果ios #将音频保存本地或上传服务器 #moltbot #漏洞挖掘 #Exchange #RXT4090显卡 #RTX4090 #深度学习服务器 #硬件选型 #万悟 #联通元景 #仙盟创梦IDE #dlms #dlms协议 #逻辑设备 #逻辑设置间权限 #SMARC #ARM # REST API # keep-alive #安全威胁分析 #源码 #闲置物品交易系统 # 代理转发 #idm #地理 #遥感 #IPv6 #reactor反应堆 #动态规划 #面向对象 # 服务器IP # 端口7860 #自由表达演说平台 #演说 #nfs #iscsi #健身房预约系统 #健身房管理系统 #健身管理系统 #AI Agent #开发者工具 #web服务器 #clamav #ThingsBoard MCP #Minecraft #Minecraft服务器 #PaperMC #我的世界服务器 # 智能运维 # 性能瓶颈分析 # GPU租赁 # 自建服务器 #前端开发 # 云服务器 #EN4FE #数据访问 #边缘AI # Kontron # SMARC-sAMX8 #智能体来了 #传统行业 #MinIO服务器启动与配置详解 #语义检索 #向量嵌入 #scanf #printf #getchar #putchar #cin #cout #磁盘配额 #存储管理 #形考作业 #国家开放大学 #系统运维 #人脸活体检测 #live-pusher #动作引导 #张嘴眨眼摇头 #苹果ios安卓完美兼容 #DHCP #gnu #remote-ssh #小艺 #搜索 #glances #duckdb #强化学习 #策略梯度 #REINFORCE #蒙特卡洛 #AI应用 #ueditor导入word #高考 #多模态 #微调 #超参 #LLamafactory #mssql # ControlMaster #阿里云RDS #Linux多线程 #Java程序员 #Java面试 #Spring源码 #b树 #cesium #可视化 #麒麟 #V11 #kylinos #memory mcp #Cursor #LED #设备树 #GPIO #信息收集 #.netcore # 模型微调 #Buck #NVIDIA #交错并联 #DGX #VMware创建虚拟机 #gerrit #实体经济 #商业模式 #数智红包 #商业变革 #创业干货 #Qwen3-VL # 服务状态监控 # 视觉语言模型 #m3u8 #HLS #移动端H5网页 #APP安卓苹果ios #监控画面 直播视频流 #Zabbix #语音合成 #全栈 #系统管理 #服务 #传媒 #隐函数 #常微分方程 #偏微分方程 #线性微分方程 #线性方程组 #非线性方程组 #复变函数 #screen命令 #超时设置 #客户端/服务器 #挖矿 #Linux病毒 #UDP服务器 #recvfrom函数 #管道Pipe #system V #身体实验室 #健康认知重构 #微行动 #NEAT效应 #亚健康自救 #ICT人 #计算机现代史 #c++高并发 #百万并发 #Termux #Samba #Ward #云计算运维 #IPMI #asp.net上传大文件 #高精度农业气象 #递归 #线性dp #webgl #uip #日志模块 #AI-native #VMware Workstation16 #服务器操作系统 #国产化OS #华为机试 #音诺ai翻译机 #AI翻译机 # Ampere Altra Max #文本生成 #CPU推理 #4U8卡 AI 服务器 ##AI 服务器选型指南 #GPU 互联 #GPU算力 #ShaderGraph #图形 # 批量管理 #全文检索 #ASR #SenseVoice #银河麒麟服务器系统 #ueditor导入pdf #GPU ##租显卡 #计算几何 #斜率 #方向归一化 #叉积 #samba #xml #投标 #标书制作 #A2A #GenAI #MCP服务器注解 #异步支持 #方法筛选 #声明式编程 #自动筛选机制 #VMWare Tool #pxe #CCE #Dify-LLM #Flexus #H5网页 #网页白屏 #H5页面空白 #资源加载问题 #打包部署后网页打不开 #HBuilderX #程序开发 #程序设计 #mvc #网络安全大赛 #idc #题解 #图 #dijkstra #迪杰斯特拉 #MinIO #pyqt #智能制造 #供应链管理 #工业工程 #库存管理 #实时检测 #量子计算 #DAG #r语言 #NSP #下一状态预测 #aigc #HarmonyOS APP #旅游 #STDIO传输 #SSE传输 #WebMVC #WebFlux #RK3588 #RK3588J #评估板 #核心板 #嵌入式开发 #SSH密钥 #服务器IO模型 #非阻塞轮询模型 #多任务并发模型 #异步信号模型 #多路复用模型 #声源定位 #MUSIC #AI电商客服 #提词器 #西门子 #汇川 #Blazor #经济学 #数据可视化 #网路编程 #zygote #应用进程 #代理模式 #Spring AOP #resnet50 #分类识别训练 #SSH代理转发 #OpenManage #C2000 #TI #实时控制MCU #AI服务器电源 #Smokeping #租显卡 #训练推理 # 树莓派 # ARM架构 #企业微信机器人 #本地大模型 #Xshell #Finalshell #生物信息学 #组学 #多进程 #python技巧 #AI 推理 #NV #Spire.Office #隐私合规 #网络安全保险 #法律风险 #风险管理 #memcache #企业级存储 #网络设备 #ServBay #大模型应用 #API调用 #PyInstaller打包运行 #服务端部署 # OTA升级 # 黄山派 #内网 # 网络延迟 #ranger #MySQL8.0 #统信UOS #win10 #qemu #zotero #WebDAV #同步失败 #轻量化 #低配服务器 #公共MQTT服务器 #代理服务器 #Langchain-Chatchat # 国产化服务器 # 信创 #智能体对传统行业冲击 #行业转型 #懒汉式 #恶汉式 #odoo #win11 #雨云服务器 #教程 #MCSM面板 # DIY主机 # 交叉编译 #Autodl私有云 #深度服务器配置 # 自动化运维 #claudeCode #content7 #0day漏洞 #DDoS攻击 #漏洞排查 #服务器架构 #AI推理芯片 #appche #视觉理解 #Moondream2 #多模态AI #c #muduo #TcpServer #accept #路由器 #Redis #分布式锁 #n8n解惑 #OpenHarmony #CS336 #Assignment #Experiments #TinyStories #Ablation #实时音视频 #ftp #sftp #工程设计 #预混 #扩散 #燃烧知识 #层流 #湍流 #余行补位 #意义对谈 #余行论 #领导者定义计划 #硬盘克隆 #DiskGenius #广播 #组播 #并发服务器 #PN 结 #ARMv8 #内存模型 #内存屏障 # 服务器迁移 # 回滚方案 #ArkUI #ArkTS #鸿蒙开发 #超算中心 #PBS #lsf #反向代理 #报表制作 #职场 #用数据讲故事 #AE #手机h5网页浏览器 #安卓app #苹果ios APP #手机电脑开启摄像头并排查 #eureka #AITechLab #cpp-python #CUDA版本 #企业存储 #RustFS #对象存储 #高可用 #三维 #3D #参数估计 #矩估计 #概率论 #系统安装 #铁路桥梁 #DIC技术 #箱梁试验 #裂纹监测 #四点弯曲 #Coturn #模块 #gmssh #宝塔 #设计规范 #放大电路 #CVE-2025-61686 #路径遍历高危漏洞 #AI应用编程 #游戏服务器断线 #运动 #期刊 #SCI #基础语法 #标识符 #常量与变量 #数据类型 #运算符与表达式 #POC #问答 #交付 #Archcraft #Linly-Talker # 数字人 # 服务器稳定性 #百度文库 #爱企查 #旋转验证码 #验证码识别 #主板 #总体设计 #电源树 #框图 #devops #okhttp #starrocks #Taiji #电子电气架构 #系统工程与系统架构的内涵 #Routine #STL #string #格式工厂 #L6 #L10 #L9 #OpenAI #故障 #lucene #Beidou #北斗 #SSR #composer #symfony #java-zookeeper #nmodbus4类库使用教程 #poll #C₃₂H₄₅N₇O₁₁S₂ #远程更新 #缓存更新 #多指令适配 #物料关联计划 #个性化推荐 #BERT模型 #proc # AI部署 # 环境迁移 #pipeline #Transformers #NLP #AI运维 #DevOps自动化 #Prometheus #二值化 #Canny边缘检测 #轮廓检测 #透视变换 #DooTask #防毒面罩 #防尘面罩 #交换机 #三层交换机 #编程助手 #个人电脑 #思爱普 #SAP S/4HANA #ABAP #NetWeaver #一人公司 #独立开发者 #sklearn # 权限修复 #WAN2.2 #Gateway #认证服务器集成详解 #uniapp #合法域名校验出错 #服务器域名配置不生效 #request域名配置 #已经配置好了但还是报错 #uniapp微信小程序 #EventLoop #后端框架 #统信操作系统 #人形机器人 #人机交互 #电梯 #电梯运力 #电梯门禁 #vncdotool #链接VNC服务器 #如何隐藏光标 #字符串 #时间复杂度 #空间复杂度 #free #vmstat #sar #FHSS #bond #服务器链路聚合 #网卡绑定 #数据报系统 #算力建设 #ETL管道 #向量存储 #数据预处理 #DocumentReader #编程语言 #spring ai #oauth2 # 高温监控 #图像分类 #图像分割 #yolo26算法 #人大金仓 #Kingbase #江协 #瑞萨 #OLED屏幕移植 #AI工具集成 #容器化部署 #2025年 #docker安装seata #Matrox MIL #二次开发 #CMC #numpy #AI教程 #一周会议与活动 #ICLR #CCF #自动化巡检 #istio #服务发现 # 串口服务器 # NPort5630 #人脸识别sdk #视频编解码 #SEW #赛威 #SEW变频器 #决策树 #cpu #RWK35xx #语音流 #实时传输 #ossinsight #node #开关电源 #热敏电阻 #PTC热敏电阻 #rag #canvas层级太高 #canvas遮挡问题 #盖住其他元素 #苹果ios手机 #安卓手机 #调整画布层级 #数据迁移 #测速 #iperf #iperf3 #adobe #SQL注入主机 #express #cherry studio # child_process #分子动力学 #化工仿真 #小智 #scikit-learn #戴尔服务器 #戴尔730 #装系统 #junit #boltbot #计算机外设 #xshell #host key #tekton #DuckDB #协议 #Arduino BLDC #核辐射区域探测机器人 #rsync # 数据同步 #Python办公自动化 #Python办公 #基金 #股票 #YOLO识别 #YOLO环境搭建Windows #YOLO环境搭建Ubuntu #jquery #fork函数 #进程创建 #进程终止 #session #api #key #AI作画 #JADX-AI 插件