orama

orama

全方位搜索引擎解决方案,支持多设备多接口使用

Orama提供全文本、向量和混合搜索功能,适用于浏览器、服务器、移动应用和边缘设备,并且体积小于2KB。主要功能包括向量搜索、混合搜索、筛选器、地理搜索、字段提升、容错和精确匹配。通过插件系统,用户可以扩展功能,支持30种语言的词干提取和标记。Orama易于安装和使用,文档详细并有社区支持,是理想的轻量级搜索解决方案。

Orama搜索引擎向量搜索混合搜索GeosearchGithub开源项目
<p align="center"> <img src="https://raw.githubusercontent.com/askorama/orama/main//misc/readme/orama-readme-dark.png#gh-dark-mode-only" /> <img src="https://raw.githubusercontent.com/askorama/orama/main//misc/readme/orama-readme-light.png#gh-light-mode-only" /> </p> <h4 align="center"> <a href="https://askorama.ai?utm_source=github">网站</a> • <a href="https://askorama.ai/blog?utm_source=github">博客</a> • <a href="https://docs.askorama.ai?utm_source=github">文档</a> • <a href="https://orama.to/slack">社区Slack</a> </h4> <br /> <p align="center"> 具有独特API的全文、向量和混合搜索。<br /> 可在您的浏览器、服务器、移动应用或边缘设备上运行。<br /> 仅需不到2kb。 </p> <br /> <p align="center" style="margin-top:5px;margin-bottom:35px"> <img src="https://raw.githubusercontent.com/askorama/orama/main//misc/readme/orama-readme-runtime-dark.png#gh-dark-mode-only" /> <img src="https://raw.githubusercontent.com/askorama/orama/main//misc/readme/orama-readme-runtime-light.png#gh-light-mode-only" /> </p>

测试 NPM下载量 jsDelivr点击量(npm) npm包大小

加入Orama的Slack频道

如果您需要更多信息、帮助或想提供有关Orama的一般反馈,请加入 Orama Slack频道

主要特性

安装

您可以使用npmyarnpnpmbun安装Orama:

npm i @orama/orama

或者直接在浏览器模块中导入:

<html> <body> <script type="module"> import { create, search, insert } from 'https://unpkg.com/@orama/orama@latest/dist/index.js' // ... </script> </body> </html>

使用Deno时,您可以使用相同的CDN URL或使用npm说明符:

import { create, search, insert } from 'npm:@orama/orama'

完整文档请访问https://docs.askorama.ai

使用方法

Orama使用起来相当简单。首先需要创建一个新的数据库实例并设置索引模式:

import { create, insert, remove, search, searchVector } from '@orama/orama' const db = await create({ schema: { name: 'string', description: 'string', price: 'number', embedding: 'vector[1536]', // 向量大小必须在模式初始化时指定 meta: { rating: 'number', }, }, })

Orama目前支持10种不同的数据类型:

类型描述示例
string字符串'Hello world'
number数值,可以是浮点数或整数42
boolean布尔值true
enum枚举值'drama'
geopoint地理坐标点{ lat: 40.7128, lon: 74.0060 }
string[]字符串数组['red', 'green', 'blue']
number[]数值数组[42, 91, 28.5]
boolean[]布尔值数组[true, false, false]
enum[]枚举值数组['comedy', 'action', 'romance']
vector[<size>]用于执行向量搜索的数值向量[0.403, 0.192, 0.830]

Orama只会索引模式中指定的属性,但允许您在需要时设置和存储额外的数据。

创建数据库实例后,您可以开始添加一些文档:

await insert(db, { name: '无线耳机', description: '体验这款噪音消除无线耳机带来的身临其境的音质。', price: 99.99, embedding: [...], meta: { rating: 4.5, }, }) await insert(db, { name: '智能LED灯泡', description: '使用这款节能智能LED灯泡控制家中的照明,兼容大多数智能家居系统。', price: 24.99, embedding: [...], meta: { rating: 4.3, }, }) await insert(db, { name: '便携式充电器', description: '使用这款小巧快速充电的便携式充电器,在外出时永不断电。', price: 29.99, embedding: [...], meta: { rating: 3.6, }, })

插入数据后,您就可以开始查询数据库了。

const searchResult = await search(db, { term: '耳机', })

在上面的例子中,您将搜索所有包含"耳机"一词的文档,查找模式中指定的每个string属性:

{ elapsed: { raw: 99512, formatted: '99μs', }, hits: [ { id: '41013877-56', score: 0.925085832971998432, document: { name: '无线耳机', description: '体验这款噪音消除无线耳机带来的身临其境的音质。', price: 99.99, meta: { rating: 4.5 } } } ], count: 1 }

您还可以将查找限制在特定属性上:

const searchResult = await search(db, { term: '身临其境的音质', properties: ['description'], })

结果:

{ elapsed: { raw: 21492, formatted: '21μs', }, hits: [ { id: '41013877-56', score: 0.925085832971998432, document: { name: '无线耳机', description: '体验这款噪音消除无线耳机带来的身临其境的音质。', price: 99.99, meta: { rating: 4.5 } } } ], count: 1 }

您可以使用非字符串数据来过滤分组和创建分面

const searchResult = await search(db, { term: '身临其境的音质', where: { price: { lte: 199.99 }, rating: { gt: 4 } }, })

执行混合和向量搜索

Orama是一个全文和向量搜索引擎。这使您可以根据特定用例采用不同的搜索范式。

要执行向量或混合搜索,您可以使用与全文搜索相同的search方法。

您只需指定要执行向量搜索的属性,以及用于执行向量相似度的向量:

const searchResult = await searchVector(db, { mode: 'vector', // 或 'hybrid' vector: { value: [...], // 用作输入的OpenAI嵌入或类似向量 property: 'embedding' // 要搜索的属性。向量搜索时必填 } })

如果你正在使用Orama安全AI代理(强烈推荐),你可以在搜索时跳过向量配置,因为官方的Orama安全AI代理插件会自动为你处理:

import { create } from '@orama/orama' import { pluginSecureProxy } from '@orama/plugin-secure-proxy' const secureProxy = secureProxyPlugin({ apiKey: '<你的公共API密钥>', defaultProperty: 'embedding', // 执行向量和混合搜索的默认属性 model: 'openai/text-embedding-ada-002' // 用于生成嵌入的模型 }) const db = await create({ schema: { name: 'string', description: 'string', price: 'number', embedding: 'vector[1536]', meta: { rating: 'number', }, }, plugins: [secureProxy] }) const resultsHybrid = await search(db, { mode: 'vector', // 或 'hybrid' term: '适合对冰淇淋充满热情的小孩子的电子游戏', where: { price: { lte: 19.99 }, 'meta.rating': { gte: 4.5 } } })

执行地理搜索

Orama支持将地理搜索作为搜索过滤器。它将搜索通过schema中指定为geopoint的所有属性:

import { create, insert } from '@orama/orama' const db = await create({ schema: { name: 'string', location: 'geopoint' } }) await insert(db, { name: '米兰大教堂', location: { lat: 45.46409, lon: 9.19192 } }) await insert(db, { name: '大教堂广场', location: { lat: 45.46416, lon: 9.18945 } }) await insert(db, { name: '皇家小广场', location: { lat: 45.46339, lon: 9.19092 } }) const searchResult = await search(db, { term: '大教堂', where: { location: { // 我们想要过滤的属性 radius: { // 我们想要应用的过滤器(在这种情况下:"radius") coordinates: { // 中心坐标 lat: 45.4648, lon: 9.18998 }, unit: 'm', // 测量单位。默认为"m"(米) value: 1000, // 半径长度。在这种情况下,1公里 inside: true // 我们是否想返回半径内或半径外的文档。默认为"true" } } } })

Orama地理搜索API支持基于距离的搜索(通过radius)或基于多边形的搜索(通过polygon)。

默认情况下,Orama将使用Haversine公式来执行地理搜索,但可以通过在radiuspolygon配置中传递highPrecision选项来启用高精度搜索。这将告诉Orama使用Vicenty公式,它对于更长距离的计算更精确。

官方文档中阅读更多内容。

官方文档

完整文档请访问https://docs.askorama.ai

官方Orama插件

编写你自己的插件:https://docs.askorama.ai/open-source/plugins/writing-your-own-plugins

许可证

Orama采用Apache 2.0许可证。

编辑推荐精选

堆友

堆友

多风格AI绘画神器

堆友平台由阿里巴巴设计团队创建,作为一款AI驱动的设计工具,专为设计师提供一站式增长服务。功能覆盖海量3D素材、AI绘画、实时渲染以及专业抠图,显著提升设计品质和效率。平台不仅提供工具,还是一个促进创意交流和个人发展的空间,界面友好,适合所有级别的设计师和创意工作者。

图像生成AI工具AI反应堆AI工具箱AI绘画GOAI艺术字堆友相机AI图像热门
码上飞

码上飞

零代码AI应用开发平台

零代码AI应用开发平台,用户只需一句话简单描述需求,AI能自动生成小程序、APP或H5网页应用,无需编写代码。

Vora

Vora

免费创建高清无水印Sora视频

Vora是一个免费创建高清无水印Sora视频的AI工具

Refly.AI

Refly.AI

最适合小白的AI自动化工作流平台

无需编码,轻松生成可复用、可变现的AI自动化工作流

酷表ChatExcel

酷表ChatExcel

大模型驱动的Excel数据处理工具

基于大模型交互的表格处理系统,允许用户通过对话方式完成数据整理和可视化分析。系统采用机器学习算法解析用户指令,自动执行排序、公式计算和数据透视等操作,支持多种文件格式导入导出。数据处理响应速度保持在0.8秒以内,支持超过100万行数据的即时分析。

AI工具酷表ChatExcelAI智能客服AI营销产品使用教程
TRAE编程

TRAE编程

AI辅助编程,代码自动修复

Trae是一种自适应的集成开发环境(IDE),通过自动化和多元协作改变开发流程。利用Trae,团队能够更快速、精确地编写和部署代码,从而提高编程效率和项目交付速度。Trae具备上下文感知和代码自动完成功能,是提升开发效率的理想工具。

AI工具TraeAI IDE协作生产力转型热门
AIWritePaper论文写作

AIWritePaper论文写作

AI论文写作指导平台

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

AI辅助写作AI工具AI论文工具论文写作智能生成大纲数据安全AI助手热门
博思AIPPT

博思AIPPT

AI一键生成PPT,就用博思AIPPT!

博思AIPPT,新一代的AI生成PPT平台,支持智能生成PPT、AI美化PPT、文本&链接生成PPT、导入Word/PDF/Markdown文档生成PPT等,内置海量精美PPT模板,涵盖商务、教育、科技等不同风格,同时针对每个页面提供多种版式,一键自适应切换,完美适配各种办公场景。

AI办公办公工具AI工具博思AIPPTAI生成PPT智能排版海量精品模板AI创作热门
潮际好麦

潮际好麦

AI赋能电商视觉革命,一站式智能商拍平台

潮际好麦深耕服装行业,是国内AI试衣效果最好的软件。使用先进AIGC能力为电商卖家批量提供优质的、低成本的商拍图。合作品牌有Shein、Lazada、安踏、百丽等65个国内外头部品牌,以及国内10万+淘宝、天猫、京东等主流平台的品牌商家,为卖家节省将近85%的出图成本,提升约3倍出图效率,让品牌能够快速上架。

iTerms

iTerms

企业专属的AI法律顾问

iTerms是法大大集团旗下法律子品牌,基于最先进的大语言模型(LLM)、专业的法律知识库和强大的智能体架构,帮助企业扫清合规障碍,筑牢风控防线,成为您企业专属的AI法律顾问。

下拉加载更多