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

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源代码

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.1LUA_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$@ /O2 /I$(LUA_INC) /DWIN32 /D_CRT_SECURE_NO_DEPRECATE $(DRIVER_INCLUDE) $

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

编译成功:

a49afd48bc6c412d79a037ce5d10fe44.png

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

functionrows (connection, sql_statement)local cursor = assert(connection:execute (sql_statement))return function()returncursor:fetch()end

end

for name,email in rows(conn ,"SELECT * from people") do

print(string.format("%s %s",name,email))endconn:close()--关闭数据库连接

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

执行结果:

>lua -e "io.stdout:setvbuf 'no'" "sql.lua"

Jose das Couves jose@couves.com

Manoel Joaquim manoel.joaquim@cafundo.com

Maria das Dores maria@dores.com

>Exit code: 0

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值