Correct mistakes in the sqlite.lua example

Changes:
- The open flag: sqlite.OPEN_CREATE will open the DB for reading and
  writing, adding sqlite.OPEN_READWRITE to sqlite.OPEN_CREATE will cause
  the DB to not be created and prevent the script from continuing
- When using stmt:bind_parameter_index() the parameter needs to be
  prefixed with ':' if that was used in the prepared statement,
  otherwise the incorrect index of 0 is returned.
- The drop table statement has an "x" appended to the table name, looks
  like a typo.

Patch by Travis Paul

Closes PR misc/50493
This commit is contained in:
kamil 2015-12-08 23:04:40 +00:00
parent 7cbc092f17
commit 8ad8b0676c

View File

@ -1,4 +1,4 @@
-- $NetBSD: sqlite.lua,v 1.2 2014/07/19 18:38:34 lneto Exp $
-- $NetBSD: sqlite.lua,v 1.3 2015/12/08 23:04:40 kamil Exp $
local sqlite = require 'sqlite'
@ -13,8 +13,7 @@ print('this is sqlite ' .. sqlite.libversion() .. ' (' ..
sqlite.libversion_number() .. ')')
print('sourceid ' .. sqlite.sourceid())
db, state = sqlite.open('/tmp/db.sqlite',
sqlite.OPEN_READWRITE + sqlite.OPEN_CREATE)
db, state = sqlite.open('/tmp/db.sqlite', sqlite.OPEN_CREATE)
if state ~= sqlite.OK then
print('db open failed')
@ -33,7 +32,7 @@ else
print('statement has ' .. stmt:bind_parameter_count() .. ' parameters')
print('param 1 name: ' .. stmt:bind_parameter_name(1))
print('param name is at index ' .. stmt:bind_parameter_index('name'))
print('param name is at index ' .. stmt:bind_parameter_index(':name'))
stmt:bind(1, 'Hardmeier')
stmt:step()
@ -49,7 +48,7 @@ else
end
s2:finalize()
stmt = db:prepare('drop table testx')
stmt = db:prepare('drop table test')
stmt:step()
stmt:finalize()
db:close()
@ -57,4 +56,3 @@ end
print('shutdown sqlite')
sqlite.shutdown()