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

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 /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.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 jose@couves.com
Manoel Joaquim manoel.joaquim@cafundo.com
Maria das Dores maria@dores.com
>Exit code: 0

轉轉請注明出處:http://www.cnblogs.com/zhangdongsheng 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM