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.libT=mysqlDRIVER_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)\luasqlcopy src\$T.dll $(LUA_LIBDIR)\luasqlclean:del src\$T.dlldel src\$T.expdel src\$T.libdel $(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 doprint(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
endfor name,email in rows(conn ,"SELECT * from people") doprint(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

转转请注明出处:http://www.cnblogs.com/zhangdongsheng

复制去Google翻译翻译结果

lua连接数据库之luasql ------ luasql连接mysql数据库 及 luasql源码编译相关推荐

  1. python:实现连接mysql数据库(附完整源码)

    python:实现连接mysql数据库 可以使用Python的mysql-connector库实现连接MySQL数据库.以下是一个简单的源代码示例: import mysql.connector# 连 ...

  2. 【PHP】一文详解如何连接Mysql数据库(附源码)

  3. mysql5.5.8编译安装_Mysql应用linux下mysql 5.5.8 源码编译安装

    <MysqL应用linux下MysqL 5.5.8 源码编译安装>要点: 本文介绍了MysqL应用linux下MysqL 5.5.8 源码编译安装,希望对您有用.如果有疑问,可以联系我们. ...

  4. php 查看mysql连接数据库_php基础之连接mysql数据库和查询数据

    php基础之连接mysql数据库和查询数据 文章主要介绍了php连接mysql数据库和查询数据的方法和示例,需要的朋友可以参考下,就跟随百分网小编一起去了解下吧,想了解更多相关信息请持续关注我们应届毕 ...

  5. php连接数据库语言,PHP语言连接MYSQL数据库实例代码

    本文主要向大家介绍了PHP语言连接MYSQL数据库实例代码,通过具体的内容向大家展示,希望对大家学习php语言有所帮助. 现在做的项目需要php连接mysql数据库,虽然之前学过,但是现在基本上都给忘 ...

  6. python怎么连接数据库_python3.x怎么连接mysql数据库

    第三步连接mysql数据库之后,就可以通过sql语句来读取数据库内容了,完整代码如下: import pymysql.cursor # 连接MySQL数据库 connection = pymysql. ...

  7. ubuntu 环境下调试mysql源码_【转】Ubuntu 16.04下 Mysql 5.7.17源码编译与安装

    Ubuntu 16.04下 Mysql5.7.17源码编译与安装 系统环境 一. 系统安装条件 1.cmake MySQL使用cmake跨平台工具预编译源码,用于设置mysql的编译参数. sudo ...

  8. MySQL 8.0.22 源码编译安装全过程

    墨墨导读: Mysql的8.0版本出来已经有一段时间了,近期研究下源码调试.整个编译过程越来越复杂了. 近期研究下源码调试,MySQL5.7版本源码安装还是比较简单的,有很多例子参考.所以这次选择My ...

  9. python 实现学生信息管理系统+MySql 数据库,包含源码及相关实现说明~

    学生信息管理系统 1.系统说明 python 编写的学生信息管理系统+MySQL数据库,实现了增删改查的基本功能. 2.数据库说明 本人使用的是 MySQL8.0 版本 数据库端口号为:3306 数据 ...

最新文章

  1. python常用单词下载_python编程词汇
  2. 【opencv】9.批量命名图片文件std::sprintf
  3. Google 开源图形着色器测试框架 GraphicsFuzz
  4. 天池算法赛——广东电网智慧现场作业挑战赛 赛道三:识别高空作业及安全带佩戴
  5. 软件可靠性的一些关注点
  6. Nginx源码分析 - Event事件篇 - Epoll事件模块(19)
  7. 对 String 字符串的理解
  8. php asp网站本地调试,php/asp网站程序本地调试工具
  9. 雅诗兰黛公司将收购Dr. Jart+
  10. 开源大阅兵:盘点那些走向世界的中国项目
  11. 从一道题理解什么是java的引用
  12. kernel下msm的版本信息
  13. Google Dremel数据模型详解
  14. mysql中文名字段引起的触发器语法错误
  15. 积分学在计算机行业的应用,浅谈积分激励在计算机项目教学中的应用.doc
  16. C语言进阶剖析 13 接续符和转义符
  17. 电话号码的数字组合(Java)
  18. 网络安全--2.4--路由篇--01--静态路由
  19. 云师大计算机宿舍,云南师范大学宿舍条件、住宿好吗、寝室情况
  20. VBA通过一定规律匹配后另存为文件

热门文章

  1. javascript获取FileUpLoad上传空间的文件大小
  2. Linux策略路由和iptables OUTPUT链的一个细节
  3. war3 win8系统 在11对战平台 切屏后 无法切回游戏
  4. 为什么需要对LPARAM进行不必要的转换?
  5. 商业模式新生代_一年300+本读书计划之《商业模式新生代》
  6. esp8266接入机智云
  7. PSIM软件的数字控制官方例程
  8. 如何解决桌面图标消失/变白
  9. matplotlib设置中文字体
  10. 制作基于springboot的简易学生管理系统(详细)