w3resource

Using Better SQLite3 for Fast SQLite Operations in Node.js


Better SQLite3: High-Performance SQLite for Node.js

better-sqlite3 is a powerful and high-performance Node.js library for interacting with SQLite databases. It focuses on providing an easy-to-use, synchronous API that supports both simplicity and performance. Unlike other SQLite libraries for Node.js, such as sqlite3, better-sqlite3 eliminates the complexity of callbacks and promises by leveraging synchronous execution.

This library is ideal for applications that require SQLite integration with Node.js, where speed and simplicity are essential.


Installing Better SQLite3

Use npm or yarn to install the library:

npm install better-sqlite3

Syntax Overview

better-sqlite3 allows executing SQL commands through simple method calls on the database instance.

const Database = require('better-sqlite3');
const db = new Database('database_name.db', options);
  • Database: Import the better-sqlite3 module.
  • new Database(): Opens or creates an SQLite database file.
  • options: Optional object with settings like memory, readonly, or fileMustExist.

Examples Using Better SQLite3

Example 1: Basic Setup and Table Creation

Code:

// Import the better-sqlite3 library
const Database = require('better-sqlite3');

// Open (or create) an SQLite database file
const db = new Database('example.db');

// Create a new table called 'users'
db.exec(`
  CREATE TABLE IF NOT EXISTS users (
    id INTEGER PRIMARY KEY AUTOINCREMENT,
    name TEXT NOT NULL,
    age INTEGER
  );
`);

console.log('Table created successfully');

Explanation:

  • This example sets up a database named example.db and creates a users table if it doesn't already exist.
  • The db.exec method executes a SQL command without returning results.

Example 2: Inserting Data

Code:

// Prepare an INSERT statement
const insert = db.prepare('INSERT INTO users (name, age) VALUES (?, ?)');

// Insert user data
insert.run('Alice', 25);
insert.run('Bob', 30);

console.log('Data inserted successfully');

Explanation:

  • prepare compiles a SQL query for repeated execution.
  • run executes the prepared query with provided parameters.

Example 3: Fetching Data

Code:

// Prepare a SELECT statement
const select = db.prepare('SELECT * FROM users');

// Fetch all rows
const rows = select.all();

console.log('User Data:', rows);

Explanation:

  • The all method retrieves all matching rows as an array of objects.

Example 4: Updating and Deleting Data

Code:

// Prepare an UPDATE statement
const update = db.prepare('UPDATE users SET age = ? WHERE name = ?');
update.run(35, 'Alice');

// Prepare a DELETE statement
const del = db.prepare('DELETE FROM users WHERE name = ?');
del.run('Bob');

console.log('Data updated and deleted successfully');

Explanation:

  • Update and delete operations are straightforward with better-sqlite3, using prepare and run.

Advantages of Better SQLite3

    1. Simplicity: Synchronous execution eliminates callback hell and promise chains.

    2. Performance: Faster than many asynchronous SQLite libraries due to optimized native bindings.

    3. Ease of Use: Intuitive API for executing queries and managing transactions.

    4. Transactions: Supports transactional operations for complex workflows.


Error Handling in Better SQLite3

Use try-catch blocks to handle errors during database operations.

Code:

try {
  db.exec('INVALID SQL');
} catch (error) {
  console.error('Database error:', error.message);
}

Use Cases of Better SQLite3

  • Small to medium-sized web applications using SQLite as a lightweight database.
  • Desktop applications built with Electron or similar frameworks.
  • Command-line tools that need database functionality.

Conclusion

better-sqlite3 simplifies SQLite integration in Node.js by providing a synchronous API that balances performance and usability. Its features make it a reliable choice for developers who prefer straightforward database operations without sacrificing efficiency.

Practical Guides to SQLite Snippets and Examples.



Follow us on Facebook and Twitter for latest update.