加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 大数据 > 正文

lua连接数据库之luasql ------ luasql连接mysql数据库 及 luasql

发布时间:2020-12-14 22:14:28 所属栏目:大数据 来源:网络整理
导读:lua连接数据库不只luasql这个库,但目前更新最快的的貌似是这个luasql,他是开源的,支持的数据库功能如下: Connect to ODBC,ADO,Oracle,MySQL,SQLite and PostgreSQL databases; Execute arbitrary SQL statements; Retrieve results in a row-by-row curs

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: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()   关闭数据库环境
?执行结果:

>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

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读