lua连接数据库之luasql ------ luasql连接mysql数据库 及 luasql
lua连接数据库不只luasql这个库,但目前更新最快的的貌似是这个luasql,他是开源的,支持的数据库功能如下:
源码直接编译就得到一个dll,这个dll可以被c++或lua引用 1.首先下载luasql源代码 http://www.keplerproject.org/luasql/index.html#download,我是直接上他的Github然后用totoisesvn ? checkOut了一份源码 2.编译 LUA_INC=D:Lua5.1include LUA_DIR=D:Lua5.1 LUA_LIBDIR=D:Lualib LUA_LIB=D:Lua5.1liblua5.1.lib T=mysql DRIVER_INCLUDE= /I"D:UpupwMySQLinclude" DRIVER_LIBS= D:UpupwMySQLliblibmySQL.lib" "D:UpupwMySQLlibmysqlclient.lib" OBJS= srcluasql.obj srcls_$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() 关闭数据库环境 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |