The ultimate
multi-model database

Develop easier. Build faster. Scale quicker.

View all features
Get started with SurrealDB
SurrealDB offers a dynamic and adaptable platform for business. With an integrated suite of cutting-edge database solutions, tools, and services, SurrealDB empowers your workforce to discover innovative answers using products meticulously crafted to meet their requirements.
Database, realtime API layer, and security permissions all-in-one

Database, realtime API layer, and security permissions all-in-one

SurrealDB combines the database layer, the querying layer, and the API and authentication layer into one platform. Advanced table-based and row-based customisable access permissions allow for granular data access patterns for different types of users. There's no need for custom backend code and security rules with complicated database development.

View all features
Connect and query directly from web-browsers and client devices

Connect and query directly from web-browsers and client devices

Connect directly to SurrealDB from any end-user client device. Run SurrealQL queries directly within web-browsers, ensuring that users can only view or modify the data that they are allowed to access. Highly-performant WebSocket connections allow for efficient bi-directional queries, responses and notifications.

View all features
Query the database with the tools you want. Your data, your choice.

Query the database with the tools you want. Your data, your choice.

SurrealDB is designed to be flexible to use, with support for SurrealQL, GraphQL (coming soon), CRUD support over REST, and JSON-RPC querying and modification over WebSockets. With direct-to-client connection with in-built permissions, SurrealDB speeds up the development process, and fits in seamlessly into any tech stack.

View all features
Advanced inter-document relations and analysis. No JOINs. No pain.

Advanced inter-document relations and analysis. No JOINs. No pain.

With full graph database functionality, SurrealDB enables more advanced querying and analysis. Records (or vertices) can be connected to one another with edges, each with its own record properties and metadata. Simple extensions to traditional SQL queries allow for multi-table, multi-depth document retrieval, efficiently in the database, without the use of complicated JOINs and without bringing the data down to the client.

View all features
Tables, documents, and graph. Store and model your data in any way

Tables, documents, and graph. Store and model your data in any way

As a multi-model database, SurrealDB enables developers to use multiple techniques to store and model data, without having to choose a method in advance. With the use of tables, SurrealDB has similarities with relational databases, but with the added functionality and flexibility of advanced nested fields and arrays. Inter-document record links allow for simple to understand and highly-performant related queries without the use of JOINs, eliminating the N+1 query problem.

View all features
Simple schema definition for frontend and backend development

Simple schema definition for frontend and backend development

With SurrealDB, specify your database and API schema in one place, and define column rules and constraints just once. Once a schema is defined, database access is automatically granted to the relevant users. No more custom API code, and no more GraphQL integration. Simple, flexible, and ready for production in minutes, not months.

View all features
Realtime live queries and data changes direct to application

Realtime live queries and data changes direct to application

SurrealDB keeps every client device in-sync with data modifications pushed in realtime to the clients, applications, end-user devices, and server-side libraries. Live SQL queries allow for advanced filtering of the changes to which a client subscribes, and efficient data formats, including DIFFing and PATCHing enable highly-performant web-based data syncing.

View all features
Scale effortlessly to hundreds of nodes for high-availability and scalability

Scale effortlessly to hundreds of nodes for high-availability and scalability

SurrealDB can be run as a single in-memory node, or as part of a distributed cluster - offering highly-available and highly-scalable system characteristics. Designed from the ground up to run in a distributed environment, SurrealDB makes use of special techniques when handling multi-table transactions, and document record IDs - with no use of table or row locks.

View all features
Extend your database with JavaScript and WebAssembly functions

Extend your database with JavaScript and WebAssembly functions

Embedded JavaScript functions allow for advanced, custom functionality, with computation logic being moved to the data layer. This improves upon the traditional approach of moving data to the client devices before applying any computation logic, ensuring that only the necessary data is transferred remotely. These advanced JavaScript functions, with support for the ES2020 standard, allow any developer to analyse the data in ever more simple-yet-advanced ways.

View all features
Designed to be embedded or to run distributed in the cloud

Designed to be embedded or to run distributed in the cloud

Built entirely in Rust as a single library, SurrealDB is designed to be used as both an embedded database library with advanced querying functionality, and as a database server which can operate in a distributed cluster. With low memory usage and cpu requirements, SurrealDB has been specifically designed to run in all types of environment.

View all features
SurrealDB makes building and scaling realtime apps dramatically quicker and easier. Get started by installing the server, and jump into our getting started guide to learn how to insert and query data in SurrealDB in minutes.
Get started

Loved by developers

"Here at Yaacomm we are already using SurrealDB in a significant way for our backend infrastructure, however I believe SurrealDB can play an even bigger role in other areas as well. Being able to embed SurrealDB locally in Android and iOS apps could make it a perfect fit for local caching. Additionally, this would provide us with all the benefits of SurrealDB such as full-text searching and its graph based nature without relying on a network connection."
View the case study
"It think it's going to change how we query databases."
Anup Jadhav
Director, Partner Delivery Success, C360 Cross-Cloud, Salesforce
Anup Jadhav
"Now that it's at 1.0, there is a pretty good use case to using it in some serious projects."
Jeff Delaney
Web Developer and Tech Influencer, Fireship
Jeff Delaney
"Throughout my years dealing with database challenges, SurrealDB seems to be a beacon of innovation. Addressing issues like multi-tenancy, blending the best of hybrid & distributed databases, and ensuring unmatched scalability & performance. Oh and btw it had ML integrated in the database - how cool is that! But the true standout? Live queries and change feeds. Such features are not just advancements, they're revolutions in how we handle data. Goes to show the evolution of databases are not over yet!!"
Rajani Rao FRSA MBCS
R&D Principal Technologist, Aveva
Rajani Rao FRSA MBCS
"Exciting things are happening in the Tech industry. Bun just announced version 1.0 is prod ready. And now SurrealDB is launching stable version 1.0. This is the most significant shift in my decade-long developer experience. Excited to see what's next!"
Necmettin Karakaya
Lead Software Engineer, Figment
Necmettin Karakaya
"It's fast, small, can run on browser, edge and cloud. It can handle large data. It can run in-memory like redis or disk like sqlite and it can run multi-cluster. It can sync between cloud and edge. And to top of it off, it can also run as a graphdb. It's interesting."
Chris Hay
CTO, IBM iX
Chris Hay
"It's incredible what SurrealDB provides and also what's coming up in the near future. Embedding, scaling, machine learning, live queries... SurrealDB as an event store or persisted broker or IoT platform - I've so many ideas right now for the next project. Awesome!"
Sebastian Wessel
Senior Developer
"Very excited to put these capabilities into practice."
Travis Barney
Principal Engineer, Vivint
Travis Barney
"SurrealDB looks amazing. Cloud-native Database written in Rust using SQL for structured and unstructured data, graph querying, full-text indexing, and geospatial querying, while supporting row-level permissions."
Reza Qorbani
Co-founder and CTO, Qualia
Reza Qorbani