lua连接数据库不只luasql这个库,但目前更新最快的的貌似是这个luasql,他是开源的,支持的数据库功能如下:
- Connect 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引用
http://www.keplerproject.org/luasql/index.html#download,我是直接上他的Github然后用totoisesvn checkOut了一份源码
2.编译
我使用的是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\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$@ /O2 /I$(LUA_INC) /DWIN32 /D_CRT_SECURE_NO_DEPRECATE $(DRIVER_INCLUDE) $< src\$T.dll: $(OBJS) link /dll /def:src\$T.def /out:$@ $(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.MysqL 就OK了编译成功后会在src目录下生成MysqL.dll
编译成功:
3.使用方法
由于使用起来很简单,仿照官方的例子写了个查询语句都是可以的,我就直接上代码了
require "luasql.MysqL" --创建环境对象 env = assert(luasql.MysqL()) 连接数据库 conn = assert(env:connect(ly",root"*****192.168.1.553306)) 操作数据数据库 conn:executeSET 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 --]] 操作数据库文法2 function rows (connection,sql_statement) local cursor = (connection:execute (sql_statement)) return () return cursor:fetch() end end for name,email in rows(conn,0); line-height:1.5!important">SELECT * from people") do print(string.format(%s %s",name,email)) end conn:close() 关闭数据库连接 env:close() 关闭数据库环境
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。