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

Flink SQL 的 USE / USE CATALOG / USE MODULES(Catalog、Database、Module 三件套)

1、USE CATALOG:切换当前 Catalog

USECATALOG cat1;

含义:把“当前 catalog”设置为cat1
之后你写:

SHOWDATABASES;CREATETABLEt1(...);

如果没有显式写catalog.db.table的全限定名,Flink 会默认把对象解析到cat1这个 catalog 里。

默认值default_catalog
不存在会怎样:直接抛异常(这点非常重要,很多人以为会自动创建)。

2、USE:切换当前 Database(可带 catalog 前缀)

USEdb1;

含义:把当前 database 设置成db1
之后你写CREATE TABLE Orders (...),它会落在:
当前catalog.db1.Orders

也可以写全一点:

USEcat1.db1;

这相当于一次性把 catalog + database 都切到目标位置(具体支持程度以你环境对 catalog/database 的实现为准,但语义就是“按前缀解析”)。

默认 databasedefault_database
db 不存在:抛异常。

3、USE MODULES:切换“函数/类型/规则”的解析顺序(非常实用,也非常容易忽略)

USEMODULES hive;

这句不是切 catalog/db,而是控制“元数据解析优先级”。它影响的典型对象包括:

  • 内置/扩展函数(比如 hive 内置函数)
  • 用户自定义类型(UDT)
  • 规则、元数据解析(文档里统称 metadata)
3.1 什么是解析顺序?

当你执行:

SELECTmy_func(x)FROMt;

Flink 会按USE MODULES声明的顺序去查找my_func到底来自哪个模块。
如果你启用了多个模块,还能指定优先级:

USEMODULES hive,core;

意思就是:优先在 hive 模块里找,找不到再去 core 里找。

3.2 “loaded” 与 “used”的区别(核心坑点)

文档含义是:

  • 模块被load后,默认是used=true(可用)
  • 但一旦你执行USE MODULES ...只有出现在列表里的模块会保持 used
    没出现在列表里的,即使已经 loaded,也会变成disabled(used=false)

所以你会看到类似:

SHOWFULLMODULES;-- hive true-- core false

这就是为什么“我之前还能用的函数突然找不到了”的典型原因之一:你换了模块启用列表。

4、Java 里怎么用?(executeSql 返回 OK 的那种)

在 Java(TableEnvironment / StreamTableEnvironment)里,你直接:

tEnv.executeSql("USE CATALOG cat1");tEnv.executeSql("USE db1");tEnv.executeSql("USE MODULES hive");

成功会返回OK(或者对应的 TableResult 可打印),失败则抛异常。
建议你在平台化/脚本执行场景里,把每一次USE都当成“可能失败的边界”,明确 catch 并记录上下文(当前 catalog/db/modules)。

5、一套推荐的“工程化用法”(避免环境漂移)

如果你在写作业/平台,强烈建议遵循这三条:

  1. 任何 DDL/DML 执行前,显式 USE CATALOG + USE db
    避免默认的default_catalog.default_database导致表建错位置。

  2. 模块切换要谨慎USE MODULES hive会导致 core 被禁用(不在列表里)
    如果你依赖 core 的函数或规则,记得把它放进列表里:

    USEMODULES hive,core;
  3. 对外提供 SQL 执行能力时:建议每个会话隔离上下文
    因为USE改的是“会话级的当前上下文”,很容易造成串环境问题。

6、总结

  • USE CATALOG xxx:切换当前 catalog(默认default_catalog
  • USE dbUSE catalog.db:切换当前数据库(默认default_database
  • USE MODULES ...:控制函数/类型/规则等元数据解析来源与优先级(默认模块core
  • 三者组合决定:你不写全限定名时,SQL 到底解析到哪里、函数到底用哪个实现
http://www.cnnetsun.cn/news/135958.html

相关文章:

  • 服务器性能优化实战:从资源瓶颈定位到极致调优(附租赁服务器适配指南)
  • 三相异步电动机交流调速系统:原理、应用与优化控制策略
  • 3、数据科学命令行入门指南
  • Wireshark抓包模式选择:5个关键场景与实战技巧
  • 10、数据探索与可视化全攻略
  • 小学生学C++编程 (自定义函数(二))
  • GPT-5.2国内稳定接入实战:中转调用方案全解析(适配中小团队Python栈)
  • macOS存储空间告急?iSCSI Initiator终极解决方案助你突破存储瓶颈
  • 5分钟快速掌握:用node-qrcode打造专业级二维码
  • 杭亚 YS - 01H 声光报警器用户心得
  • 扔掉PuTTY!我用这款“瑞士军刀”实现了运维效率翻倍
  • Clipper2深度解析:掌握多边形裁剪与偏移的终极利器
  • Web 项目地图选型指南:从 Leaflet 到 MapTalks,如何选择合适的地图引擎?
  • 7、Windows应用开发中的用户界面控件使用指南
  • 18、Windows 应用数据管理全解析
  • AI大模型微调完全指南:13分钟让小模型“开挂“超越GPT-5,程序员必备收藏!
  • 汇编语言全接触-34.RichEdit 控件:更多的正文操作
  • 汇编语言全接触-35.RichEdit 控件:语法高亮显示
  • 自养号测评:跳出“隐形工具”定位,筑牢品牌增长核心基建
  • 昂瑞微推出了面向移动电源行业的一站式智能方案-OM70201MV
  • Mobox移动桌面体验优化指南:极致显示与性能调校
  • 23、Web与互联网管理及服务器日志分析
  • LPxxR100FN_36W/48W/60W开关电源100V同步整流芯片典型应用电路(LP20R100FN,LP20R100FN,LP10R100FN)
  • SHP文件GCJ02转WGS84坐标系系统源码
  • ComfyUI智能字幕生成终极指南:轻松为图片添加精准描述 [特殊字符]
  • ComfyUI智能字幕生成终极指南:3步实现AI自动化图片标注
  • 2025亚马逊运营升级:从短期竞争,转向品牌资产长效经营
  • 【大前端】【iOS】iOS 真实项目可落地目录结构方案
  • “在我电脑上明明是好的”:我用这套云原生工作流,终结了团队内耗
  • 揭秘MCP服务发现:构建智能AI工具生态系统的核心技术