当前位置: 首页 > news >正文

有没有做装修的大型网站而不是平台学校网站建设目的及功能定位

有没有做装修的大型网站而不是平台,学校网站建设目的及功能定位,彩票网站建设制作价格,微信公众平台登录入口官网可以借助 DolphinScheduler 调度工具,实现从 Doris 查询联合主键记录并传递到 MySQL 执行删除操作,需要结合 SQL 任务、Shell 任务和 参数传递 功能。 以下是具体步骤: 1. 创建工作流并添加 Doris 查询任务 首先添加一个 SQL 任务 查询 Do…

可以借助 DolphinScheduler 调度工具,实现从 Doris 查询联合主键记录并传递到 MySQL 执行删除操作,需要结合 SQL 任务Shell 任务参数传递 功能。

以下是具体步骤:

1. 创建工作流并添加 Doris 查询任务

首先添加一个 SQL 任务 查询 Doris 表中的联合主键:

  1. 任务类型:选择 SQL
  2. 数据源:选择已配置的 Doris 数据源
  3. SQL 语句
    SELECT GROUP_CONCAT(CONCAT_WS(',', id1, id2) ,'|') AS primary_key  -- 联合主键字段用逗号连接
    FROM doris_table
    WHERE condition = 'value'
    
  4. 任务名称:例如 query_doris_pk
  5. 高级配置:勾选 将查询结果保存为变量,变量名设为 pk_list

语法解析

  1. CONCAT_WS(',', id1, id2)

    • 将联合主键 id1id2 用逗号 , 连接,例如 id1=1id2=234 会转为 1,234
  2. GROUP_CONCAT(... SEPARATOR '|')

    • 将所有 CONCAT_WS 结果用竖线 | 连接,形成最终的一行字符串。
    • 例如三条记录会转为 1,234|5,678|9,1011

注意事项

  1. NULL 值处理

    • CONCAT_WS 会忽略 NULL 值,若主键可能为 NULL,建议先使用 COALESCE 处理:
    CONCAT_WS(',', COALESCE(id1, ''), COALESCE(id2, ''))
    
  2. 性能优化

    • 大数据量时,GROUP_CONCAT 可能导致内存问题,建议先过滤数据或分批处理。
  3. 字符集兼容

    • 确保 Doris 表的字符集与后续处理兼容(如 MySQL 的 UTF8 字符集)。

2. 添加 Shell 任务处理结果

添加一个 Shell 任务 处理查询结果,生成 MySQL 删除语句:

  1. 任务类型:选择 Shell
  2. 脚本内容
    # 读取 Doris 查询结果
    PK_LIST="${pk_list}"# 生成 MySQL 删除语句
    DELETE_SQL="DELETE FROM mysql_table WHERE (id1, id2) IN ("# 处理每条记录
    IFS='|' read -ra RECORDS <<< "$PK_LIST"
    for RECORD in "${RECORDS[@]}"; do# 分割联合主键IFS=',' read -ra KEYS <<< "$RECORD"DELETE_SQL+="('${KEYS[0]}','${KEYS[1]}'),"
    done# 移除最后一个逗号并闭合括号
    DELETE_SQL="${DELETE_SQL%,}"
    DELETE_SQL+=");"# 输出结果供下游任务使用
    echo "DELETE_SQL=${DELETE_SQL}"
    

代码解析:
(1) IFS='|' read -ra RECORDS <<< "$PK_LIST"
这是一段在 Shell 脚本中的命令。具体含义为:首先将内部字段分隔符(IFS)设置为竖线 “|” ,这意味着在后续读取操作中,竖线将作为字段分隔标识。然后使用read命令结合-ra选项来读取数据,-r选项使得读取时不把反斜杠作为转义字符,-a选项用于将读取到的数据赋值给一个数组。RECORDS是定义的数组名。<<< "$PK_LIST"表示从变量PK_LIST的值中读取内容,将按照竖线分隔后的数据填充到RECORDS数组中。例如,若PK_LIST的值为 “a|b|c”,那么RECORDS数组就会包含三个元素,RECORDS[0]为 “a” ,RECORDS[1]为 “b” ,RECORDS[2]为 “c” 。

  1. 任务名称:例如 generate_delete_sql
  2. 高级配置:勾选 将脚本输出作为变量,变量名设为 delete_sql

3. 添加 MySQL 执行任务

添加一个 SQL 任务 执行生成的删除语句:

  1. 任务类型:选择 SQL
  2. 数据源:选择已配置的 MySQL 数据源
  3. SQL 语句
    ${delete_sql}
    
  4. 任务名称:例如 execute_mysql_delete

4. 工作流配置与依赖关系

  1. 工作流参数:在工作流参数中定义变量:

    pk_list = ""
    delete_sql = ""
    
  2. 任务依赖

    query_doris_pk → generate_delete_sql → execute_mysql_delete
    

5. 验证与优化

  1. 测试查询

    • 先单独运行 query_doris_pk 任务,检查 pk_list 变量是否包含正确的联合主键。
  2. SQL 安全

    • 如果主键值包含特殊字符,可能需要在 Shell 任务中增加转义处理。
  3. 批量处理

    • 对于大量数据,可将 pk_list 拆分为多个子任务,避免单条 SQL 过长。

完整工作流示例

+---------------------+      +-------------------------+      +------------------------+
| query_doris_pk      | ---> | generate_delete_sql     | ---> | execute_mysql_delete   |
| (SQL 任务)          |      | (Shell 任务)            |      | (SQL 任务)             |
| 从 Doris 查询主键    |      | 处理结果生成 SQL        |      | 执行 MySQL 删除        |
+---------------------+      +-------------------------+      +------------------------+

注意事项

  1. 变量传递限制

    • DolphinScheduler 的变量传递有长度限制(默认 4KB),大量数据可能需要通过文件中转。
  2. 事务安全

    • 确保 MySQL 表使用 InnoDB 引擎,并在删除前备份数据。

通过以上配置,我们就可以实现从 Doris 查询联合主键并在 MySQL 中删除对应记录的自动化流程。

http://www.yayakq.cn/news/853044/

相关文章:

  • 网站开发维护任职要求美工培训中心
  • 公司网页设计怎么弄网站建设优化公司呼和浩特
  • 商城网站建设信息旅游app页面设计图
  • 养车网站开发建设工程施工范围
  • 西安网站开发公司有哪家好加强人社网站建设
  • 阿里云网站建设和部署框架中时讯通信建设有限公司网站
  • 北京哪家做网站和网络推广好的移动端网站开发公司
  • 微网站 php免费wap网站制作
  • 推广引流系统常德自助建站seo
  • 济南网站托管网站维护的主要工作
  • 中国石家庄网站网络服务器机柜
  • 杭州 网站开发公司网站链接做二维码
  • 建设局施工许可证网站腾讯建设网站视频视频下载
  • 自助免费网站建设平台网站cms大全
  • 小说网站开发教程seo推广多少钱
  • 系统首页设计网站seo工作内容
  • 做班级网站代码网页代码怎么查看
  • 梁山做网站价格注册开发公司
  • 个人可以建网站卖东西吗郑州华久做网站
  • 专业做网站建设公互联网公司网站建设价格
  • 成都三合一网站建设固原网站建设公司
  • 网站开发工具推荐wordpress的标题字体大小
  • 婴儿辅食中企动力提供网站建设如何在手机上做自己的网站6
  • 网站建设的业务好做吗网站设计与建设工作室
  • 小程序免费制作平台源码如何选择百度网站优化公司
  • 旅游网站建设经济评价网站报404错误怎么解决办法
  • 福田住房和建设局网站官网怎样做网站制作团队
  • 做个网站多少钱 百度能查到的佛山网站建设明细
  • 中国旅游网站的建设企业内训机构
  • 框架做网站指的是重庆建设工程信息网址