Skip to content

Latest commit

 

History

History
145 lines (103 loc) · 3.03 KB

README.md

File metadata and controls

145 lines (103 loc) · 3.03 KB

dbAdmin

dbAdmin is a Lua module designed for interacting with SQLite databases. It provides functionalities to list tables, get the record count of a table, and execute SQL queries.

Features

  • List all tables in the database
  • Get the record count of a specific table
  • Execute any SQL query

Installation

Ensure you have the lsqlite3 library installed. You can install it using LuaRocks:

Copy the src/main.lua file to your project directory as DbAdmin.lua.

Usage

Creating an Instance

Create a new dbAdmin instance by passing an SQLite database connection.

local sqlite3 = require("lsqlite3")
local dbAdmin = require("DbAdmin")

-- Open the database
local db = sqlite3.open_memory()

-- Create a new dbAdmin instance
local admin = dbAdmin.new(db)

Listing Tables

List all tables in the database.

local tables = admin:tables()
print("Tables:")
for _, table in ipairs(tables) do
    print(table)
end

Getting Record Count

Get the record count of a specific table.

local count = admin:count('your_table_name')
print(string.format("Record count in 'your_table_name': %d", count))

Applying Inserts, Updates and Deletes

Insert a record using parameters

admin:apply('insert into names (id, name) values (NULL, ?));', { "SpongeBob" })
admin:apply('insert into names (id, name) values (NULL, ?));', { "Patrick" })

Update a record using parameters

admin:apply('update names set (name = ? ) where id = ?;', { "SpongeBob", 1 })
admin:apply('update names set (name = ? ) where id = ?;', { "Patrick", 2 })
admin:apply('delete from names where id = ?;', { 1 })
admin:apply('delete from names where id = ?;', { 2 })

SQL Selects using parameters

local results = admin:select('select * from names where id = ?', { 1 })

Executing SQL Queries

Execute a given SQL query and retrieve the results.

local results = admin:exec("SELECT * FROM your_table_name;")
print("Query Results:")
for _, row in ipairs(results) do
    for k, v in pairs(row) do
        print(k, v)
    end
end

Example

Here's a complete example demonstrating how to use the dbAdmin module:

local sqlite3 = require("lsqlite3")
local dbAdmin = require("DbAdmin")

-- Open the database
local db = sqlite3.open_memory()

-- Create a new dbAdmin instance
local admin = dbAdmin.new(db)

-- List all tables
local tables = admin:tables()
print("Tables:")
for _, table in ipairs(tables) do
    print(table)
end

-- Get the record count of a specific table
local count = admin:count('your_table_name')
print(string.format("Record count in 'your_table_name': %d", count))

-- Execute a query and print the results
local results = admin:exec("SELECT * FROM your_table_name;")
print("Query Results:")
for _, row in ipairs(results) do
    for k, v in pairs(row) do
        print(k, v)
    end
end

Testing

aos dbadmin-tests --sqlite
.load-blueprint apm
APM.install('@rakis/test-unit')
.load src/run_tests.lua

License

This project is licensed under the MIT License.