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许可证。

编辑推荐精选

GPT Plus|Pro充值

GPT Plus|Pro充值

GPT充值

支持 ChatGPT Plus / Pro 充值服务,支付便捷,自动发货,售后可查。

GPT Image 2中文站

GPT Image 2中文站

AI 图片生成平台

GPT Image 2 是面向用户的 AI 图片生成平台,支持文生图、图生图及多模型创意工作流。

Vecbase

Vecbase

你的AI Agent团队

Vecbase 是专为 AI 团队打造的智能工作空间,将数据管理、模型协作与知识沉淀整合于一处。算法、产品与业务在同一平台无缝协同,让从数据到 AI 应用的落地更快一步。

音述AI

音述AI

全球首个AI音乐社区

音述AI是全球首个AI音乐社区,致力让每个人都能用音乐表达自我。音述AI提供零门槛AI创作工具,独创GETI法则帮助用户精准定义音乐风格,AI润色功能支持自动优化作品质感。音述AI支持交流讨论、二次创作与价值变现。针对中文用户的语言习惯与文化背景进行专门优化,支持国风融合、C-pop等本土音乐标签,让技术更好地承载人文表达。

QoderWork

QoderWork

阿里Qoder团队推出的桌面端AI智能体

QoderWork 是阿里推出的本地优先桌面 AI 智能体,适配 macOS14+/Windows10+,以自然语言交互实现文件管理、数据分析、AI 视觉生成、浏览器自动化等办公任务,自主拆解执行复杂工作流,数据本地运行零上传,技能市场可无限扩展,是高效的 Agentic 生产力办公助手。

lynote.ai

lynote.ai

一站式搞定所有学习需求

不再被海量信息淹没,开始真正理解知识。Lynote 可摘要 YouTube 视频、PDF、文章等内容。即时创建笔记,检测 AI 内容并下载资料,将您的学习效率提升 10 倍。

AniShort

AniShort

为AI短剧协作而生

专为AI短剧协作而生的AniShort正式发布,深度重构AI短剧全流程生产模式,整合创意策划、制作执行、实时协作、在线审片、资产复用等全链路功能,独创无限画布、双轨并行工业化工作流与Ani智能体助手,集成多款主流AI大模型,破解素材零散、版本混乱、沟通低效等行业痛点,助力3人团队效率提升800%,打造标准化、可追溯的AI短剧量产体系,是AI短剧团队协同创作、提升制作效率的核心工具。

seedancetwo2.0

seedancetwo2.0

能听懂你表达的视频模型

Seedance two是基于seedance2.0的中国大模型,支持图像、视频、音频、文本四种模态输入,表达方式更丰富,生成也更可控。

nano-banana纳米香蕉中文站

nano-banana纳米香蕉中文站

国内直接访问,限时3折

输入简单文字,生成想要的图片,纳米香蕉中文站基于 Google 模型的 AI 图片生成网站,支持文字生图、图生图。官网价格限时3折活动

扣子-AI办公

扣子-AI办公

职场AI,就用扣子

AI办公助手,复杂任务高效处理。办公效率低?扣子空间AI助手支持播客生成、PPT制作、网页开发及报告写作,覆盖科研、商业、舆情等领域的专家Agent 7x24小时响应,生活工作无缝切换,提升50%效率!

下拉加载更多