• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    迪恩网络公众号

lua连接数据库之luasql ------ luasql连接mysql数据库 及 luasql源码编译 ...

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

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引用

1.首先下载luasql源代码

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\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 /[email protected] /O2 /I$(LUA_INC) /DWIN32 /D_CRT_SECURE_NO_DEPRECATE $(DRIVER_INCLUDE) $<

src\$T.dll: $(OBJS)
    link /dll /def:src\$T.def /out:[email protected] $(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.55",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
--]]
--操作数据库文法2
function rows (connection, sql_statement)
  local cursor = assert (connection:execute (sql_statement))
  return function ()
    return cursor:fetch()
  end
end

for name,email in rows(conn ,"SELECT * from people") do
    print(string.format("%s  %s",name,email))
end

conn:close()  --关闭数据库连接
env:close()   --关闭数据库环境

 执行结果:

>lua -e "io.stdout:setvbuf 'no'" "sql.lua" 
Jose das Couves [email protected]
Manoel Joaquim [email protected]
Maria das Dores [email protected]
>Exit code: 0

转转请注明出处:http://www.cnblogs.com/zhangdongsheng 

 


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
nginx图片处理笔记(http-image-filter-module、lua)发布时间:2022-07-22
下一篇:
Lua API 小记——— lua值, 栈解释发布时间:2022-07-22
热门推荐
热门话题
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap