openresty 前端開發入門五之Mysql篇

来源:http://www.cnblogs.com/ccmc/archive/2017/01/04/openresty-web-dev-5.html
-Advertisement-
Play Games

openresty 前端開發入門五之Mysql篇 這章主要演示怎麼通過lua連接mysql,並根據用戶輸入的name從mysql獲取數據,並返回給用戶 操作mysql主要用到了lua resty mysql庫,代碼可以在 "github" 上找得到 而且上面也有實例代碼 由於官網給出的例子比較基本, ...


openresty 前端開發入門五之Mysql篇

這章主要演示怎麼通過lua連接mysql,並根據用戶輸入的name從mysql獲取數據,並返回給用戶

操作mysql主要用到了lua-resty-mysql庫,代碼可以在github上找得到

而且上面也有實例代碼

由於官網給出的例子比較基本,代碼也比較多,所以我這裡主要介紹一些怎麼封裝一下,簡化我們調用的代碼

lua/mysql.lua

local mysql = require "resty.mysql"

local config = {
    host = "localhost",
    port = 3306,
    database = "mysql",
    user = "root",
    password = "admin"
}

local _M = {}


function _M.new(self)
    local db, err = mysql:new()
    if not db then
        return nil
    end
    db:set_timeout(1000) -- 1 sec

    local ok, err, errno, sqlstate = db:connect(config)

    if not ok then
        return nil
    end
    db.close = close
    return db
end

function close(self)
    local sock = self.sock
    if not sock then
        return nil, "not initialized"
    end
    if self.subscribed then
        return nil, "subscribed state"
    end
    return sock:setkeepalive(10000, 50)
end

return _M

其實就是簡單把連接,跟關閉做一個簡單的封裝,隱藏繁瑣的初始化已經連接池細節,只需要調用new,就自動就鏈接了redis,close自動使用連接池

lua/hello.lua

local cjson = require "cjson"
local mysql = require "mysql"
local req = require "req"

local args = req.getArgs()

local name = args['name']

if name == nil or name == "" then
    name = "root"   
end

name = ngx.quote_sql_str(name) -- SQL 轉義,將 ' 轉成 \', 防SQL註入,並且轉義後的變數包含了引號,所以可以直接當成條件值使用

local db = mysql:new()

local sql = "select * from user where User = " .. name

ngx.say(sql)
ngx.say("<br/>")

local res, err, errno, sqlstate = db:query(sql)
db:close()
if not res then
    ngx.say(err)
    return {}
end

ngx.say(cjson.encode(res))

訪問
http://localhost/lua/hello?name=root

即可獲取mysql中的name為root的的所有用戶,如果沒有name參數,則預設獲取root的值

從輸出的數據中,可以看出res其實是一個數組,而且不管返回的數據是多少條,它都是一個數組,當我們查詢的結果只有一條的時候,可以通過 res[1] 來獲取一條記錄,每一行數據又是一個table,可以通過列名來得到value

ok,到這裡我們已經可以獲取用戶輸入的值,並且從mysql中獲取數據,然後返回json數據了,已經可以開發一些簡單的介面了

示例代碼 參見demo5部分



您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • ...
  • --1:無ORDER BY排序的寫法。(效率最高) --(經過測試,此方法成本最低,只嵌套一層,速度最快!即使查詢的數據量再大,也幾乎不受影響,速度依然!) SELECT * FROM (SELECT ROWNUM AS rowno, t.* FROM emp t WHERE hire_date B ...
  • 今天,有個哥們碰到一個問題,他有一個從庫,只要是啟動MySQL,CPU使用率就非常高,其中sys占比也比較高,具體可見下圖。 註意:他的生產環境是物理機,單個CPU,4個Core。 於是,他抓取了CPU的歷史信息,發現CPU飆高大概是從2017年1月1日8點10分開始的。 但是這個從庫的負載並不高, ...
  • alter table [表名] alter column [欄位名][ 屬性] 例子: 把Student表中Sno的int類型 修改為 varchar 類型 alter table Student alter column Sno varchar(20) not null ...
  • MYSQL常用的一些知識點,作為WEB開發者只會使用CURE還不太行啊。 ...
  • 首先下載安裝文件,打開後文件結構如圖所示: 首先下載安裝文件,打開後文件結構如圖所示: 安裝之前請關閉Windows防火牆並斷開網路。 xp系統下直接雙擊運行(本經驗以XP系統安裝為例進行講述)。 如果是在win7上安裝,如圖:在setup文件上點擊右鍵,選擇以“管理員身份運行”。 xp系統下直接雙 ...
  • SQL Check? 一款實時監測SQL資料庫性能、實時排查的問題的免費工具。 可以實時監測20個左右的SQL關鍵性能指標,每個指標都已圖形化動態直播形式展現。 適合DBA、資料庫管理人員應急處理資料庫突發的性能問題,如死鎖、阻塞等,迅速定位性能瓶頸的根源。 主要特點 1. 吞吐量監控實時、直觀 實 ...
  • 資料庫:資料庫是一種以某種有組織的方式存儲的數據集合。其本質就是一個容器,通常是一個或者一組文件。 表:表示一種結構化的文件,可用來存儲某種特定類型的數據。 模式:描述資料庫中特定的表以及整個資料庫和其中表的關係。表具有一些特性,這些特性定義了數據在表中如何存儲,可以存儲什麼樣的數據,數據如何分解, ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...