zoukankan      html  css  js  c++  java
  • 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:Lua5.1include
    LUA_DIR=D:Lua5.1
    LUA_LIBDIR=D:Lua5.1lib
    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.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 

  • 相关阅读:
    逆向学习-内嵌补丁(洞穴代码)
    ubuntu下创建ftp用户,该用户只访问特定目录下的内容
    Ubuntu 14.04 FTP服务器--vsftpd的安装和配置
    Hdu 4223 Dynamic Programming?
    Hdu 3873 Invade the Mars
    Hdu 2025 查找最大元素
    Hdu 1520 Anniversary party
    Hdu 4283 You Are the One
    HTTP协议
    常用正则表达式
  • 原文地址:https://www.cnblogs.com/zhangdongsheng/p/3175738.html
Copyright © 2011-2022 走看看