随笔 - 107  文章 - 2  评论 - 39  阅读 - 11万

luasql连接mysql数据库

Lua连接数据库不只是luasql这一个库,但是luasql是开源的,支持的数据库有:

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

下载luasql源代码

http://www.keplerproject.org/luasql/index.html#download

编译

使用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 /Fo$[url=home.php?mod=space&uid=936]@[/url] /O2 /I$(LUA_INC) /DWIN32 /D_CRT_SECURE_NO_DEPRECATE $(DRIVER_INCLUDE) $<

 

src\$T.dll: $(OBJS)

    link /dll /def:src\$T.def /out:$[url=home.php?mod=space&uid=936]@[/url] $(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.mysq直接在src目录下生成mysql.dll

 

使用方法

require "luasql.mysql"

--创建环境对象

env = assert(luasql.mysql())

--连接数据库

conn = assert(env:connect("bimokudb","root","root","localhost",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

--]]

-- res=conn:execute(" insert into t_user(username,password) values('你好','123')")

-- print(res)

--操作数据库文法2

function rows (connection, sql_statement)

  local cursor = assert (connection:execute (sql_statement))

  return function ()

    return cursor:fetch()

  end

end

 

 

for ID,BOOKNAME,AUTHOR in rows(conn ,"SELECT ID,BOOKNAME,AUTHOR from t_book") do

    print(string.format("%d | %s | %s",ID,BOOKNAME,AUTHOR))

end

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

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

posted on   刀锋诚心  阅读(2601)  评论(0编辑  收藏  举报
编辑推荐:
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
阅读排行:
· 地球OL攻略 —— 某应届生求职总结
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 提示词工程——AI应用必不可少的技术
· .NET周刊【3月第1期 2025-03-02】
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

点击右上角即可分享
微信分享提示