Database connectivity for the Lua programming language


Here is an example of the basic use of the library. After that, another example shows how to create an iterator over the result of a SELECT query.

Basic use

-- load driver
require "luasql.postgres"
-- create environment object
env = assert (luasql.postgres())
-- connect to data source
con = assert (env:connect("luasql-test"))
-- reset our table
res = con:execute"DROP TABLE people"
res = assert (con:execute[[
  CREATE TABLE people(
    name  varchar(50),
    email varchar(50)
-- add a few elements
list = {
  { name="Jose das Couves", email="", },
  { name="Manoel Joaquim", email="", },
  { name="Maria das Dores", email="", },
for i, p in pairs (list) do
  res = assert (con:execute(string.format([[
    INSERT INTO people
    VALUES ('%s', '%s')]],,
-- retrieve a cursor
cur = assert (con:execute"SELECT name, email from people")
-- print all rows, the rows will be indexed by field names
row = cur:fetch ({}, "a")
while row do
  print(string.format("Name: %s, E-mail: %s",,
  -- reusing the table of results
  row = cur:fetch (row, "a")
-- close everything

And the output of this script should be:

Name: Jose das Couves, E-mail:
Name: Manoel Joaquim, E-mail:
Name: Maria das Dores, E-mail:

Iterator use

It may be useful to offer an iterator for the resulting rows:

function rows (connection, sql_statement)
  local cursor = assert (connection:execute (sql_statement))
  return function ()
    return cursor:fetch()

Here is how the iterator is used:

require "luasql.mysql"
env = assert (luasql.mysql())
con = assert (env:connect"my_db")
for id, name, address in rows (con, "select * from contacts") do
  print (string.format ("%s: %s", name, address))

The above implementation relies on the garbage collector to close the cursor. It could be improved to give better error messages (including the SQL statement) or to explicitly close the cursor (by checking whether there are no more rows).

Valid XHTML 1.0!

$Id: examples.html,v 1.15 2007/10/30 01:10:49 carregal Exp $