Lua连接数据库不只是luasql这一个库,但是luasql是开源的,支持的数据库有:
Connection to ODBC,ADO,Oracle,MySQL,SQLite and PostgreSQL databases;
Execute arbitrary SQL statements
Retrieve results in a row-by-row cursor fashion
源代码编译可以得到一个dll,这个dll可以被c++或lua引用
下载luasql源代码
编译
使用vs2012打开vs2012命令提示符下面,cd到刚才下载的源码的目录,由于 我只想连接mysql数据库所以别的都没编译只编译了MakeFile.win.mysql这个。注意要用记事打开这个MakeFile.win.mysql这个makefile改一下里面的lua包含目录、库目录等,编译这个,还需要mysql的包含目录以及mysql的静态库libmySQL.lib和mysqlclient.lib,下面是我改后的makefile文件
LUA_INC=D:\Lua\5.1\include
LUA_DIR=D:\Lua\5.1
LUA_LIBDIR=D:\Lua\5.1\lib
LUA_LIB=D:\Lua\5.1\lib\lua5.1.lib
T=mysql
DRIVER_INCLUDE= /I"D:\Upupw\MySQL\include"
DRIVER_LIBS= "D:\Upupw\MySQL\lib\libmySQL.lib" "D:\Upupw\MySQL\lib\mysqlclient.lib"
OBJS= src\luasql.obj src\ls_$T.obj
.c.obj:
cl /c /Fo$[url=home.php?mod=space&uid=936]@[/url] /O2 /I$(LUA_INC) /DWIN32 /D_CRT_SECURE_NO_DEPRECATE $(DRIVER_INCLUDE) $<
src\$T.dll: $(OBJS)
link /dll /def:src\$T.def /out:$[url=home.php?mod=space&uid=936]@[/url] $(OBJS) $(DRIVER_LIBS) $(LUA_LIB)
install:
IF NOT EXIST $(LUA_LIBDIR)\luasql mkdir $(LUA_LIBDIR)\luasql
copy src\$T.dll $(LUA_LIBDIR)\luasql
clean:
del src\$T.dll
del src\$T.exp
del src\$T.lib
del $(OBJS)
直接 nmake /f Makefile.win.mysq直接在src目录下生成mysql.dll
使用方法
require "luasql.mysql"
--创建环境对象
env = assert(luasql.mysql())
--连接数据库
conn = assert(env:connect("bimokudb","root","root","localhost",3306))
--操作数据数据库
conn:execute"SET NAMES GB2312"
--执行数据库操作
--下面这种方式有问题,貌似和lua库有关
--[[
cur = conn:execute("SELECT * from people")
row = cur:fetch({},"a")
while row do
print(string.format("%s %s",row.name,row.email))
row = cur:fetch(row,"a")
end
--]]
-- res=conn:execute(" insert into t_user(username,password) values('你好','123')")
-- print(res)
--操作数据库文法2
function rows (connection, sql_statement)
local cursor = assert (connection:execute (sql_statement))
return function ()
return cursor:fetch()
end
end
for ID,BOOKNAME,AUTHOR in rows(conn ,"SELECT ID,BOOKNAME,AUTHOR from t_book") do
print(string.format("%d | %s | %s",ID,BOOKNAME,AUTHOR))
end
conn:close() --关闭数据库连接
env:close() --关闭数据库环境