Alasql
AlaSQL.js - JavaScript SQL database for browser and Node.js. Handles both traditional relational tables and nested JSON data (NoSQL). Export, store, and import data from localStorage, IndexedDB, or Excel.
Install / Use
/learn @AlaSQL/AlasqlREADME
-
AlaSQL is an unfunded open source project installed 650k+ times each month. Please donate your time. We appreciate any and all contributions we can get.
-
Have a question? Ask The AlaSQL Bot or post on Stack Overflow.
AlaSQL
<h2 align="center"><a href="http://alasql.org"><img src="https://cloud.githubusercontent.com/assets/1063454/19309516/94f8007e-9085-11e6-810f-62fd60b42185.png" alt="AlaSQL logo" styl="max-width:80%"/></a> </h2>AlaSQL - ( à la SQL ) [ælæ ɛskju:ɛl] - is an open source SQL database for JavaScript with a strong focus on query speed and data source flexibility for both relational data and schemaless data. It works in the web browser, Node.js, and mobile apps.
This library is perfect for:
- Fast in-memory SQL data processing for BI and ERP applications on fat clients
- Easy ETL and options for persistence by data import / manipulation / export of several formats
- All major browsers, Node.js, and mobile applications
We focus on speed by taking advantage of the dynamic nature of JavaScript when building up queries. Real-world solutions demand flexibility regarding where data comes from and where it is to be stored. We focus on flexibility by making sure you can import/export and query directly on data stored in Excel (both .xls and .xlsx), CSV, JSON, TAB, IndexedDB, LocalStorage, and SQLite files.
The library adds the comfort of a full database engine to your JavaScript app. No, really - it's working towards a full database engine complying with most of the SQL-99 language, spiced up with additional syntax for NoSQL (schema-less) data and graph networks.
Traditional SQL Table
/* create SQL Table and add data */
alasql('CREATE TABLE cities (city string, pop number)');
alasql("INSERT INTO cities VALUES ('Paris',2249975),('Berlin',3517424),('Madrid',3041579)");
/* execute query */
var res = alasql('SELECT * FROM cities WHERE pop < 3500000 ORDER BY pop DESC');
// res = [ { "city": "Madrid", "pop": 3041579 }, { "city": "Paris", "pop": 2249975 } ]
Array of Objects
var data = [
{a: 1, b: 10},
{a: 2, b: 20},
{a: 1, b: 30},
];
var res = alasql('SELECT a, SUM(b) AS b FROM ? GROUP BY a', [data]);
// res = [ { "a": 1, "b": 40},{ "a": 2, "b": 20 } ]
Spreadsheet
// file is read asynchronously (Promise returned when SQL given as array)
alasql([
'SELECT * FROM XLS("./data/mydata") WHERE lastname LIKE "A%" and city = "London" GROUP BY name ',
])
.then(function (res) {
console.log(res); // output depends on mydata.xls
})
.catch(function (err) {
console.log('Does the file exist? There was an error:', err);
});
Bulk Data Load
alasql('CREATE TABLE example1 (a INT, b INT)');
// alasql's data store for a table can be assigned directly
alasql.tables.example1.data = [
{a: 2, b: 6},
{a: 3, b: 4},
];
// ... or manipulated with normal SQL
alasql('INSERT INTO example1 VALUES (1,5)');
var res = alasql('SELECT * FROM example1 ORDER BY b DESC');
console.log(res); // [{a:2,b:6},{a:1,b:5},{a:3,b:4}]
If you are familiar with SQL, it should be no surprise that proper use of indexes on your tables is essential for good performance.
Options
AlaSQL has several configuration options which change the behavior. It can be set via SQL statements or via the options object before using alasql.
If you're using NOW() in queries often, setting alasql.options.dateAsString to false speed things up. It will just return a JS Date object instead of a string representation of a date.
Installation
yarn add alasql # yarn
npm install alasql # npm
npm install -g alasql # global install of command line tool
For the browsers: include alasql.min.js
<script src="https://cdn.jsdelivr.net/npm/alasql@4"></script>
Getting started
See the "Getting started" section of the wiki
More advanced topics are covered in other wiki sections like "Data manipulation" and in questions on Stack Overflow
Other links:
-
Documentation: Github wiki
-
Library CDN: jsDelivr.com
-
Feedback: Open an issue
-
Try online: <a href="http://alasql.org/console?CREATE TABLE cities (city string, population number);INSERT INTO cities VALUES ('Rome',2863223), ('Paris',2249975),('Berlin',3517424), ('Madrid',3041579);SELECT * FROM cities WHERE population < 3500000 ORDER BY population DESC">Playground</a>
-
Website: alasql.org
Please note
All contributions are extremely welcome and greatly appreciated(!) - The project has never received any funding and is based on unpaid voluntary work: We really (really) love pull requests
The AlaSQL project depends on your contribution of code and <s>may</s> have bugs. So please, submit any bugs and suggestions as an issue.
Please check out the limitations of the library.
Performance
AlaSQL is designed for speed and includes some of the classic SQL engine optimizations:
- Queries are cached as compiled functions
- Joined tables are pre-indexed
WHEREexpressions are pre-filtered for joins
See more performance-related info on the wiki
Features you might like
Traditional SQL
Use "good old" SQL on your data with multiple levels of: JOIN, VIEW, GROUP BY, UNION, PRIMARY KEY, ANY, ALL, IN, ROLLUP(), CUBE(), GROUPING SETS(), CROSS APPLY, OUTER APPLY, WITH SELECT, and subqueries. The wiki lists supported SQL statements and keywords.
User-Defined Functions in your SQL
You can use all benefits of SQL and JavaScript together by defining your own custom functions. Just add new functions to the alasql.fn object:
alasql.fn.myfn = function (a, b) {
return a * b + 1;
};
var res = alasql('SELECT myfn(a,b) FROM one');
You can also define your own aggregator functions (like your own SUM(...)). See more in the wiki
Compiled statements and functions
var ins = alasql.compile('INSERT INTO one VALUES (?,?)');
ins(1, 10);
ins(2, 20);
See more in the wiki
SELECT against your JavaScript data
Group your JavaScript array of objects by field and count number of records in each group:
var data = [
{a: 1, b: 1, c: 1},
{a: 1, b: 2, c: 1},
{a: 1, b: 3, c: 1},
{a: 2, b: 1, c: 1},
];
var res = alasql('SELECT a, COUNT(*) AS b FROM ? GROUP BY a', [data]);
See more ideas for creative data manipulation in the wiki
JavaScript Sugar
AlaSQL extends "good old" SQL to make it closer to JavaScript. The "sugar" includes:
-
Write Json objects -
{a:'1',b:@['1','2','3']} -
Access object properties -
obj->property->subproperty -
Access object and arrays elements -
obj->(a*1) -
Access JavaScript functions -
obj->valueOf() -
Format query output with
SELECT VALUE, ROW, COLUMN, MATRIX -
Output nested objects with
INTO OBJECT()- converts arrow notation columns back to nested structure -
ES5 multiline SQL with
var SQL = function(){/*SELECT 'MY MULTILINE SQL'*/}and pass instead of SQL string (will not work if you compress your code)
Extracting Nested Properties with INTO OBJECT()
When selecting nested properties using arrow notation (->), resul
Related Skills
feishu-drive
326.5k|
things-mac
326.5kManage Things 3 via the `things` CLI on macOS (add/update projects+todos via URL scheme; read/search/list from the local Things database)
clawhub
326.5kUse the ClawHub CLI to search, install, update, and publish agent skills from clawhub.com
codebase-memory-mcp
766High-performance code intelligence MCP server. Indexes codebases into a persistent knowledge graph — average repo in milliseconds. 64 languages, sub-ms queries, 99% fewer tokens. Single static binary, zero dependencies.
