11-Oracle 23ai Vector Embbeding和ONNX
Embedding (模型嵌入)是 AI 领域的一个核心概念
一、Embedding(嵌入)的含义
- 语义相似的物体在向量空间中距离相近(如"狗"和"犬",猫和老虎这样的向量接近)。
- 语义不同的物体在向量空间中距离较远(如"汽车"和"苹果"的向量远离)。
- 向量化表示:原始数据(如一段文字) → 固定长度的数值数组(现在已经支持1024维向量)。
- 保留语义:转换后的向量能反映数据的内在含义(如近义词、相似主题的文本向量相似)。
- 非直接搜索:解决传统关键词搜索无法捕捉语义的问题(例如搜索"自动驾驶车辆"也能匹配到"无人驾驶汽车")。
二、Oracle AI Vector Search Embedding 的使用途径
1. 相似性搜索(Similarity Search)
- 原理:将用户查询(如自然语言问题)通过嵌入模型转换为向量,并在数据库中搜索与之最接近的向量。
- 应用场景:
- 文档语义搜索(输入问题 → 匹配相关文档)
- 图像/视频内容检索(输入描述 → 匹配相似媒体)
- 推荐系统(根据用户行为向量推荐相似商品)
- 欺诈检测(识别异常模式向量)
2. 检索增强生成(RAG, Retrieval-Augmented Generation)
- 工作流程:
- 生成Embedding:将用户提问(如"公司Q3财报亮点?")转换为向量。
- 相似性搜索:在私有业务数据中查找相关向量(如存储的财报文档向量)。
- 增强LLM提示:将匹配结果作为上下文输入给大语言模型(如GPT)。
- 生成精准回答:LLM基于业务数据生成准确回复,减少"幻觉"。
- 价值:
- 无需重新训练LLM即可利用私有数据(比如企业内部的作业指导书、企业合同、客服、质量追溯记录)。
- 提升聊天ROBOT、智能问答系统的准确性,Agent回答的准确度。
3. 多模态数据融合
- 支持将文本、图像、JSON等异构数据统一转换为向量,在单一数据库中执行跨模态搜索(如用文字搜索图片)。
三、Oracle AI Vector Search 中 Embedding 的实现方式
- 向量生成:
- 使用开源或商业嵌入模型(如BERT、CLIP)生成向量。支持第三方
- 支持通过 ONNX 框架导入自定义模型。
- 可在数据库内生成向量,或直接导入外部生成的向量。
- 向量存储:
- 使用新增的 VECTOR 数据类型在 Oracle Database 23ai 中存储向量。
- 向量与业务数据共存储,确保数据变更时向量同步更新。
- 向量索引与查询:
- 高效索引:使用内存图索引(如HNSW)或分区索引加速搜索。
- SQL 扩展:通过 VECTOR_DISTANCE() 等函数直接执行相似性查询。
- 精度控制:允许指定目标搜索精度(如召回率95%),而非手动调参。
- GPU 加速:利用 GPU 加速向量生成和索引构建(如处理大规模图像/视频嵌入)。
四、Oracle Embedding 的核心特性
1. 原生向量存储与处理
- VECTOR 数据类型:Oracle Database 23ai 新增原生数据类型,直接存储高维向量(如1024维)。
- 优势:无需额外数据库或中间件,与企业业务数据(关系表、JSON、空间数据)统一存储。
- 支持动态更新:业务数据变更时,关联向量自动同步(如文档内容修改后重新生成向量)。
- 维度灵活性:支持不同维数的向量(如文本向量512维、图像向量2048维),适应多模态场。
2. 向量生成自由度高
双路径支持:
- 库内生成:在数据库中直接调用嵌入模型生成向量(需导入ONNX模型)。
- 外部导入:允许从第三方工具(如Python训练脚本)生成向量后导入。
- 模型无关性:支持任意嵌入模型(开源如BERT、CLIP或商业私有模型),无和厂商绑定。
3. 企业级性能优化
- GPU 加速:利用 GPU 加速向量生成(如大规模文本/图像嵌入)和索引构建。
- 用例:处理百万级参数的医疗影像PACS数据的嵌入生成时间从小时级降至分钟级。
- Exadata 专属优化:Exadata 24ai 的软硬件协同优化向量搜索,索引创建速度提升10倍+,高净值用户独享。
4. 精准控制与易用性
- 目标精度导向:创建索引时直接指定目标召回率(如 ACCURACY 95%),而非手动调整HNSW参数。
- 价值:开发者无需理解底层索引算法,降低使用门槛。
- SQL 原生扩展:通过新增SQL函数(如 VECTOR_DISTANCE())执行相似性搜索,与业务查询无缝融合。
- 示例:
-
SELECT doc_id, content FROM documents ORDER BY VECTOR_DISTANCE(embedding, :query_vector) FETCH FIRST 10 ROWS ONLY; -- 返回最相似的10个文档
五、Oracle ONNX基本概念
4.1 ONNX(Open Neural Network Exchange)
- ONNX是Open Neural Network Exchange的缩写,即开放神经网络交换。
- ONNX是一种用于存储和交换机器学习模型的开放标准格式,旨在实现不同深度学习框架(如PyTorch、TensorFlow、MXNet等)之间的互操作性。
- ONNX的主要功能和用途是使得AI模型可以在不同的框架和环境下交互使用,同时硬件和软件厂商可以基于ONNX标准优化模型性能,让所有兼容ONNX标准的框架受益。
- ONNX就像是不同深度学习框架之间的”翻译官”,让模型可以在不同框架间自由转换。
- 例如用PyTorch训练了的模型(model.pt),可以转换成ONNX格式的模型(model.onnx),然后部署运行。
4.2 ONNX Runtime 在Oracle数据库中的集成
- Oracle Database 23ai集成了AI Vector Search等功能,支持VECTOR 数据类型,可以直接在 Oracle Database 23ai 中存储向量。如果想使用AI Vector Search等功能,首先将文本等信息转换成vector,这就需要embedding模型。作为最为全能和强大的数据库,Oracle提供了各种支持,当其他数据库还需要各种插件支持的时候,
- Oracle 23ai数据库对ONNX Runtime 进行了集成,允许导入包括embedding模型等ONNX格式的AI模型到数据库中使用。提供了Python实用程序包帮助用户把其他预训练模型转换为ONNX格式的模型。
六、ONNX 框架在 Oracle Embedding 中的关键作用
1. 统一模型部署接口
- ONNX支持跨框架模型互操作(如PyTorch → TensorFlow → ONNX)。
- Oracle 集成:
- 将训练好的嵌入模型(如PyTorch训练的文本编码器)导出为ONNX格式。
- 直接导入ONNX模型至Oracle数据库,注册为可调用函数。
2. 嵌入模型的生命周期管理
- 模型库管理:
BEGINDBMS_VECTOR.IMPORT_MODEL(model_name => 'my_embedding_model',format => 'ONNX',location => 'DIR_MODELS',file_name => 'bert_text_encoder.onnx'); END;
-
调用生成向量:使用SQL函数调用模型,实时生成嵌入:
UPDATE documents SET embedding = VECTOR_EMBED(model => 'my_embedding_model', text => content -- 对content字段生成向量 );
3. 关键优势
- 避免跨系统调用:传统方案需部署独立模型服务(如Python API),Oracle通过ONNX在数据库内完成推理,减少网络延迟与运维成本。
- 企业级安全:模型与数据均在数据库内运行,满足隐私合规要求(如GDPR、HIPAA)。
- 动态更新模型:替换ONNX模型文件即可升级嵌入算法,无需停服。
相关文章:

11-Oracle 23ai Vector Embbeding和ONNX
Embedding (模型嵌入)是 AI 领域的一个核心概念 一、Embedding(嵌入)的含义 Embedding 是一种将 非结构化数据(如文本、图像、音频、视频)转换为 数值向量的技术。 其核心是通过 嵌入模型(…...
Build a Large Language Model (From Scratch) 序章
关于本书 《从零构建大型语言模型》旨在帮助读者全面理解并从头创建类似GPT的大型语言模型(LLMs)。 全书首先聚焦于文本数据处理的基础知识和注意力机制的编码,随后指导读者逐步实现一个完整的GPT模型。书中还涵盖了预训练机制以及针对文本…...
【HarmonyOS 5】教育开发实践详解以及详细代码案例
以下是基于 HarmonyOS 5 的教育应用开发实践详解及核心代码案例,结合分布式能力与教育场景需求设计: 一、教育应用核心开发技术 ArkTS声明式UI 使用 State 管理学习进度状态,LocalStorageProp 实现跨页面数据同步(如课程…...
NoSQL 之Redis哨兵
目录 一、Redis 哨兵模式概述 (一)背景与核心目标 (二)基本架构组成 (三)核心功能 二、哨兵模式实现原理 (一)配置关键参数 (二)哨兵节点的定时任务 …...
【nano与Vim】常用命令
使用nano编辑器 保存文件 : 按下CtrlO组合键,然后按Enter键确认文件名。 退出编辑器 : 按下CtrlX组合键。 使用vi或vim编辑器 保存文件 : 按Esc键退出插入模式,然后输入:w并按Enter键保存文件。 退出编辑器 …...

OpenCV 图像色彩空间转换与抠图
一、知识点: 1、色彩空间转换函数 (1)、void cvtColor( InputArray src, OutputArray dst, int code, int dstCn 0, AlgorithmHint hint cv::ALGO_HINT_DEFAULT ); (2)、将图像从一种颜色空间转换为另一种。 (3)、参数说明: src: 输入图像,即要进行颜…...

Amazing晶焱科技:电子系统产品在多次静电放电测试后的退化案例
在我们的电子设计世界里,ESD(静电放电)问题总是让人头疼。尤其是当客户面临系统失效的困境时,寻找一个能够彻底解决问题的方案就变得格外重要。这一次,我们要谈的是一个经典案例:电子系统产品在多次静电放电…...
Go 中的 Map 与字符处理指南
Go 中的 Map 与字符处理指南 在 Go 中,map 可以存储字符,但需要理解字符在 Go 中的表示方式。在 Go 语言中,"字符" 实际上有两种表示方法:byte(ASCII 字符)和 rune(Unicode 字符&…...
互联网大厂Java求职面试:云原生架构下的微服务网关与可观测性设计
互联网大厂Java求职面试:云原生架构下的微服务网关与可观测性设计 郑薪苦怀着忐忑的心情走进了会议室,对面坐着的是某大厂的技术总监张总,一位在云原生领域有着深厚积累的专家。 第一轮面试:微服务网关的设计挑战 张总…...
C++中const关键字详解:不同情况下的使用方式
在 C 中,const 关键字用于指定一个对象或变量是常量,意味着它的值在初始化之后不能被修改。下面详细介绍 const 修饰变量、指针、类对象和类中成员函数的区别以及注意事项。 修饰变量 详细介绍 当 const 修饰变量时,该变量成为常量&#x…...
Java 2D 图形类总结与分类
一、基本形状类 这些类用于绘制简单的标准几何形状。 1. 圆形 / 椭圆类 Ellipse2D:椭圆基类,支持浮点精度。 子类: Ellipse2D.Double:双精度浮点坐标。Ellipse2D.Float:单精度浮点坐标。 参数:x, y, wid…...

C# 快速检测 PDF 是否加密,并验证正确密码
引言:为什么需要检测PDF加密状态? 在批量文档处理系统(如 OCR 文字识别、内容提取、格式转换)中,加密 PDF 无法直接操作。检测加密状态可提前筛选文件,避免流程因密码验证失败而中断。 本文使用 Free Spire…...
服务器信任质询
NSURLSession 与 NSURLAuthenticationMethodServerTrust —— 从零开始的“服务器信任质询”全流程 目标读者:刚接触 iOS 网络开发、准备理解 HTTPS 与证书校验细节的同学 出发点:搞清楚为什么会有“质询”、质询的触发时机、以及在 delegate 里怎么正确…...

华为云Flexus+DeepSeek征文| 华为云Flexus X实例单机部署Dify-LLM应用开发平台全流程指南
华为云FlexusDeepSeek征文| 华为云Flexus X实例单机部署Dify-LLM应用开发平台全流程指南 前言一、相关名词介绍1.1 华为云Flexus X实例介绍1.2 Dify介绍1.3 DeepSeek介绍1.4 华为云ModelArts Studio介绍 二、部署方案介绍2.1 方案介绍2.2 方案架构2.3 需要资源2.4 本…...

Python: 操作 Excel折叠
💡Python 操作 Excel 折叠(分组)功能详解(openpyxl & xlsxwriter 双方案) 在处理 Excel 报表或数据分析时,我们常常希望通过 折叠(分组)功能 来提升表格的可读性和组织性。本文将详细介绍如何使用 Python 中的两个主流 Excel 操作库 —— openpyxl 和 xlsxwriter …...

IBM官网新闻爬虫代码示例
通常我们使用Python编写爬虫,常用的库有requests(发送HTTP请求)和BeautifulSoup(解析HTML)。但这里需要注意的是,在爬取任何网站之前,务必遵守该网站的robots.txt文件和相关法律法规,…...
Java持久层技术对比:Hibernate、MyBatis与JPA的选择与应用
目录 简介持久层技术概述Hibernate详解MyBatis详解JPA详解技术选型对比最佳实践与应用场景性能优化策略未来发展趋势总结与建议 简介 在Java企业级应用开发中,持久层(Persistence Layer)作为连接业务逻辑与数据存储的桥梁,其技…...
Spring Boot实现接口时间戳鉴权
Spring Boot实现接口时间戳鉴权,签名(sign)和时间戳(ts)放入请求头(Header)。 一、请求头参数设计 参数名类型说明tsLong13位时间戳(Unix毫秒值),必填&…...

视觉SLAM基础补盲
3D Gaussian Splatting for Real-Time Radiance Field Rendering SOTA方法3DGS contribution传统重建基于点的渲染NeRF 基础知识补盲光栅化SFM三角化极线几何标准的双目立体视觉立体匹配理论与方法立体匹配的基本流程李群和李代数 李群和李代数的映射李代数的求导李代数解决求导…...
STM32外设问题总结
SPI: ①.软件SPI和硬件SPI有什么不一样? 答:软件SPI需要在代码中进行配置相关代码,如配置引脚等,而硬件SPI的话是它已经在硬件上已经配置好SPI了,已经可以直接实现,所以可以直接使…...

Vue-3-前端框架Vue基础入门之VSCode开发环境配置和Tomcat部署Vue项目
文章目录 1 安装配置VSCode1.1 安装中文语言插件1.2 主题颜色1.3 禁用自动更新1.4 开启代码提示设置1.5 安装open in browser插件2 安装配置nodejs2.1 配置环境变量2.2 npm与maven的区别2.3 使用npm避坑3 创建Vue项目3.1 两种创建方式3.2 package.json3.3 安装新的依赖3.4 运行…...
动态IP与静态IP:数字世界的“变脸术”与“身份证”
目录 动态IP:互联网的“游牧民族” 静态IP:数字世界的“常驻公民” 动态VS静态:场景驱动的选择逻辑 未来演进:IP地址的“液态化”趋势 选型指南:没有最好,只有最合适 在互联网的海洋里,每个…...

“一代更比一代强”:现代 RAG 架构的演进之路
编者按: 我们今天为大家带来的文章,作者的观点是:RAG 技术的演进是一个从简单到复杂、从 Naive 到 Agentic 的系统性优化过程,每一次优化都是在试图解决无数企业落地大语言模型应用时出现的痛点问题。 文章首先剖析 Naive RAG 的基…...

My图床项目
引言: 在海量文件存储中尤其是小文件我们通常会用上fastdfs对数据进行高效存储,在现实生产中fastdfs通常用于图片,文档,音频等中小文件。 一.项目中用到的基础组件(Base) 1.网络库(muduo) 我们就以muduo网络库为例子讲解IO多路复用和reactor网络模型 1.1 IO多路复用 我们可以…...
SpringBoot3项目架构设计与模块解析
一、项目概述 这是一个基于SpringBoot3构建的企业级后台管理系统,从项目结构来看,系统采用了经典的分层架构设计,包含完整的控制器层、服务层、数据访问层和实体层。项目整合了Web开发、数据库访问、权限控制等核心功能模块。 二、项目整体…...
C#文件压缩与解压缩全攻略:使用ZipFile与ZipArchive实现高效操作
C#文件压缩与解压缩全攻略:使用ZipFile与ZipArchive实现高效操作 在.NET 开发中,文件压缩与解压缩是常见的需求。无论是减少存储空间、加速网络传输,还是实现数据备份,System.IO.Compression命名空间都提供了强大的工具。本文将结…...

1、Go语言基础中的基础
摘要:马士兵教育的Go语言基础的视频笔记。 第一章:走进Golang 1.1、Go的SDK介绍 1.2、Go的项目基本目录结构 1.3、HelloWorld 1.4、编译 1.5、执行 1.6、一步到位 1.7、执行流程分析 1.8、语法注意事项 (1)源文件以"go&qu…...
Go语言基础知识总结(超详细整理)
1. Go语言简介 Go语言(又称Golang)是Google于2009年发布的开源编程语言,具备简洁、高效、并发等特点,适合服务器开发、云计算、大数据等场景。 2. 环境安装与配置 下载地址:https://golang.org/dl/安装后配置环境变量…...

buuctf——web刷题第二页
[网鼎杯 2018]Fakebook和[SWPU2019]Web1没有,共30题 目录 [BSidesCF 2020]Had a bad day [网鼎杯 2020 朱雀组]phpweb [BJDCTF2020]The mystery of ip [BUUCTF 2018]Online Tool [GXYCTF2019]禁止套娃 [GWCTF 2019]我有一个数据库 [CISCN2019 华北赛区 Day2…...

MVC与MVP设计模式对比详解
MVC(Model-View-Controller)和MVP(Model-View-Presenter)是两种广泛使用的分层架构模式,核心目标是解耦业务逻辑、数据和界面,提升代码可维护性和可测试性。以下是它们的对比详解: MVC 模式&…...