lua-8 OOP/数据库

来源:互联网 发布:centos 编译安装git 编辑:程序博客网 时间:2024/05/29 14:57

Lua 中面向对象

我们知道,对象由属性和方法组成。LUA中最基本的结构是table,所以需要用table来描述对象的属性。
lua中的function可以用来表示方法。那么LUA中的类可以通过table + function模拟出来。
至于继承,可以通过metetable模拟出来(不推荐用,只模拟最基本的对象大部分时间够用了)。
Lua中的表不仅在某种意义上是一种对象。像对象一样,表也有状态(成员变量);也有与对象的值独立的本性,特别是拥有两个不同值的对象(table)代表两个不同的对象;一个对象在不同的时候也可以有不同的值,但他始终是一个对象;与对象类似,表的生命周期与其由什么创建、在哪创建没有关系。对象有他们的成员函数,表也有:

Account = {balance = 0}function Account.withdraw (v)    Account.balance = Account.balance - vend

这个定义创建了一个新的函数,并且保存在Account对象的withdraw域内,下面我们可以这样调用:

Account.withdraw(100.00)

一个简单实例
以下简单的类包含了三个属性: area, length 和 breadth,printArea方法用于打印计算结果:

-- Meta classRectangle = {area = 0, length = 0, breadth = 0}-- 派生类的方法 newfunction Rectangle:new (o,length,breadth)  o = o or {}  setmetatable(o, self)  self.__index = self  self.length = length or 0  self.breadth = breadth or 0  self.area = length*breadth;  return oend-- 派生类的方法 printAreafunction Rectangle:printArea ()  print("矩形面积为 ",self.area)end

创建对象

创建对象是位类的实例分配内存的过程。每个类都有属于自己的内存并共享公共数据。

r = Rectangle:new(nil,10,20)

访问属性
我们可以使用点号(.)来访问类的属性:
print(r.length)
访问成员函数
我们可以使用冒号 : 来访问类的成员函数:
r:printArea()
内存在对象初始化时分配。
完整实例
以下我们演示了 Lua 面向对象的完整实例:

-- Meta classShape = {area = 0}-- 基础类方法 newfunction Shape:new (o,side)  o = o or {}  setmetatable(o, self)  self.__index = self  side = side or 0  self.area = side*side;  return oend-- 基础类方法 printAreafunction Shape:printArea ()  print("面积为 ",self.area)end-- 创建对象myshape = Shape:new(nil,10)myshape:printArea()

执行以上程序,输出结果为:
面积为 100

Lua 继承

继承是指一个对象直接使用另一对象的属性和方法。可用于扩展基础类的属性和方法。
以下演示了一个简单的继承实例:

 -- Meta classShape = {area = 0}-- 基础类方法 newfunction Shape:new (o,side)  o = o or {}  setmetatable(o, self)  self.__index = self  side = side or 0  self.area = side*side;  return oend-- 基础类方法 printAreafunction Shape:printArea ()  print("面积为 ",self.area)end

接下来的实例,Square 对象继承了 Shape 类:

Square = Shape:new()-- Derived class method newfunction Square:new (o,side)  o = o or Shape:new(o,side)  setmetatable(o, self)  self.__index = self  return oend

完整实例
以下实例我们继承了一个简单的类,来扩展派生类的方法,派生类中保留了继承类的成员变量和方法:

 -- Meta classShape = {area = 0}-- 基础类方法 newfunction Shape:new (o,side)  o = o or {}  setmetatable(o, self)  self.__index = self  side = side or 0  self.area = side*side;  return oend-- 基础类方法 printAreafunction Shape:printArea ()  print("面积为 ",self.area)end-- 创建对象myshape = Shape:new(nil,10)myshape:printArea()Square = Shape:new()-- 派生类方法 newfunction Square:new (o,side)  o = o or Shape:new(o,side)  setmetatable(o, self)  self.__index = self  return oend-- 派生类方法 printAreafunction Square:printArea ()  print("正方形面积为 ",self.area)end-- 创建对象mysquare = Square:new(nil,10)mysquare:printArea()Rectangle = Shape:new()-- 派生类方法 newfunction Rectangle:new (o,length,breadth)  o = o or Shape:new(o)  setmetatable(o, self)  self.__index = self  self.area = length * breadth  return oend-- 派生类方法 printAreafunction Rectangle:printArea ()  print("矩形面积为 ",self.area)end-- 创建对象myrectangle = Rectangle:new(nil,10,20)myrectangle:printArea()

执行以上代码,输出结果为:
面积为 100
正方形面积为 100
矩形面积为 200
函数重写
Lua 中我们可以重写基础类的函数,在派生类中定义自己的实现方式:

-- 派生类方法 printAreafunction Square:printArea ()  print("正方形面积 ",self.area)end

Lua 数据库访问

本文主要为大家介绍 Lua 数据库的操作库:LuaSQL。他是开源的,支持的数据库有:ODBC, ADO, Oracle, MySQL, SQLite 和 PostgreSQL。
本文为大家介绍MySQL的数据库连接。
LuaSQL 可以使用 LuaRocks 来安装可以根据需要安装你需要的数据库驱动。
LuaRocks 安装方法:
$ wget http://luarocks.org/releases/luarocks-2.2.1.tar.gz
tarzxpfluarocks2.2.1.tar.gz cd luarocks-2.2.1
./configure;sudomakebootstrap sudo luarocks install luasocket
$ lua
Lua 5.3.0 Copyright (C) 1994-2015 Lua.org, PUC-Rio

require “socket”
Window 下安装 LuaRocks:https://github.com/keplerproject/luarocks/wiki/Installation-instructions-for-Windows
安装不同数据库驱动:
luarocks install luasql-sqlite3
luarocks install luasql-postgres
luarocks install luasql-mysql
luarocks install luasql-sqlite
luarocks install luasql-odbc
你也可以使用源码安装方式,Lua Github 源码地址:https://github.com/keplerproject/luasql
Lua 连接MySql 数据库:

require "luasql.mysql"--创建环境对象env = luasql.mysql()--连接数据库conn = env:connect("数据库名","用户名","密码","IP地址",端口)--设置数据库的编码格式conn:execute"SET NAMES UTF8"--执行数据库操作cur = conn:execute("select * from role")row = cur:fetch({},"a")--文件对象的创建file = io.open("role.txt","w+");while row do    var = string.format("%d %s\n", row.id, row.name)    print(var)    file:write(var)    row = cur:fetch(row,"a")endfile:close()  --关闭文件对象conn:close()  --关闭数据库连接env:close()   --关闭数据库环境