日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

Lua 操作 MongoDB 数据库实例

發布時間:2024/9/20 数据库 21 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Lua 操作 MongoDB 数据库实例 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

最近有個工作是使用Nginx + Lua實現一個操作MongoDB數據庫的API,主要實現其count和query功能。之前沒有寫過Lua,于是也就勉強著上手,在cloudwu的 lua-mongo 的基礎上實現了操作MongoDB的API。

cloudwu的lua-mongo驅動實現了連接Mongo,進行find和findOne等基本操作的功能,所以在lua-mongo的基礎上增加了count和query等方法。修改的具體內容如下:

1、API基于luajit-2.0開發,相當于lua 5.1,需要使用lua-compat-5.2兼容lua 5.2

2、使用ngx.socket.tcp替換mongo.socket模塊

3、增加了count,query,auth等方法

修改之后的代碼見: lua-mongo

具體的操作MongoDB的lua代碼如下:

復制代碼 代碼如下:
-- lua mongo test script
-- utils
function string:split(sep)
? local sep, fields = sep or ":", {}
? local pattern = string.format("([^%s]+)", sep)
? self:gsub(pattern, function(c) fields[#fields + 1] = c end)
? return fields
end
-- 常量
HOST = "127.0.0.1"
PORT = 27017
KEEPALIVE_TIMEOUT = 60000
KEEPALIVE_SIZE = 100
CONN_TIMEOUT = 3000
DB_USER = "user"
DB_PASSWD = "password"
DB_NAME = "blog"
DB_COLLECTION = "article"
-- 引用
mongo = require("mongo")
cjson = require("cjson.safe")
cbson = require("bson")
-- 狀態
local status_msg = "error"
local status_code = 500
local message = "unknown error"
local mongo_query = {["category_id"] = {["$in"] = {1,2,3,4}}, ["status"] = {["$ne"] = 2}, ["create_time"] = {["$lte"] = 1427102260}}
local mongo_sort = {["create_time"] = 1}
local mongo_limit = 100
local mongo_skip = 0
local mongo_fields = { ["_id"] = false }
-- 涉及到時間的字段,需要使用bson轉化一下
if mongo_query["create_time"] then
? local create_time = mongo_query["create_time"]
? local t = type(create_time)
? if t == "table" then
??? for key, value in pairs(create_time) do
????? mongo_query["create_time"][key] = cbson.date(value)
??? end
? else
??? mongo_query["create_time"] = cbson.date(create_time)
? end
end
local conn = mongo.client({ host = HOST, port = PORT })
conn:set_timeout(CONN_TIMEOUT)
local db = conn:getDB(DB_NAME)
local reused_times = conn:get_reused_times()
if reused_times == 0 then
? db:auth(DB_USER, DB_PASSWD)
end
local col = db:getCollection(DB_COLLECTION)
local result = {}
-- count
local count, err = col:count(mongo_query)
local ok, err = conn:set_keepalive(KEEPALIVE_TIMEOUT, KEEPALIVE_SIZE)
if count ~= nil then
? result = count
? status_code = 200
? status_msg = "ok"
? message = "success"
end
-- query
local bson_obj
if mongo_sort then
? bson_obj = cbson.encode_order("$query", mongo_query, "$orderby", mongo_sort)
else
? bson_obj = cbson.encode({ ["$query"] = mongo_query })
end
local results = col:query(bson_obj, mongo_fields, mongo_skip, mongo_limit)
local ok, err = conn:set_keepalive(KEEPALIVE_TIMEOUT, KEEPALIVE_SIZE)
if results then
? for _, object in pairs(results) do
??? for key, value in pairs(object) do
????? if value == cbson.null then
??????? object[key] = cjson.null
????? else
??????? local type_name, value = cbson.type(value)
??????? object[key] = value
????? end
??? end
? end
? result = results
? status_code = 200
? status_msg = "ok"
? message = "success"
end
-- findOne
local results = col:findOne({["id"] = 14 })
local ok, err = conn:set_keepalive(KEEPALIVE_TIMEOUT, KEEPALIVE_SIZE)
if results then
? for key, value in pairs(results) do
??? if value == cbson.null then
????? results[key] = cjson.null
??? else
????? local type_name, value = cbson.type(value)
????? results[key] = value
??? end
? end
? result = results
? status_code = 200
? status_msg = "ok"
? message = "success"
end
ngx.status = status_code
json_out = cjson.encode({ status = status_msg, message = message, data = result })
ngx.header["Content-Length"] = json_out:len()
ngx.print(json_out)

來源:http://www.jb51.net/article/62871.htm

與50位技術專家面對面20年技術見證,附贈技術全景圖

總結

以上是生活随笔為你收集整理的Lua 操作 MongoDB 数据库实例的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。