亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > 綜合 > 正文

在Lua程序中使用MySQL的教程

2024-07-21 23:04:54
字體:
來源:轉載
供稿:網友

 導入MySQL

我們可以用一個簡單語句導入SQLite庫,假設Lua中正確實現并已完成。在安裝過程中,文件夾libsql包含數據庫相關的文件。

 

復制代碼 代碼如下:
mysql = require "luasql.mysql"

 

可變的MySQL將提供通過參照主MySQL表訪問該功能。
建立連接

我們可以設立一個啟動MySQL的環境,然后創建環境的連接。如下所示。

 

復制代碼 代碼如下:
local env  = mysql.mysql()
local conn = env:connect('test','root','123456')

 

上面的連接將連接到現有的MySQL文件并建立與新創建的文件的連接。
執行函數

這將有助于我們做的創建,插入,刪除,更新等,所有的數據庫操作執行簡單的功能。語法如下所示

 

復制代碼 代碼如下:
conn:execute([[ 'MySQLSTATEMENT' ]])

 

在上面的語法,我們需要確保conn是開放的和現有的MySQL連接并替換“MySQLSTATEMENT”使用正確的語句。
創建表的例子

一個簡單的創建表的示例如下所示。它創建類型為int和varchar類型,兩個參數ID和name的表。

 

復制代碼 代碼如下:
mysql = require "luasql.mysql"

 

local env  = mysql.mysql()
local conn = env:connect('test','root','123456')
print(env,conn)

status,errorString = conn:execute([[CREATE TABLE sample2 (id INTEGER, name TEXT);]])
print(status,errorString )

 

當運行上面的程序,表名為sample將有兩列分別是id和name會被創建。

 

復制代碼 代碼如下:
MySQL environment (004BB178) MySQL connection (004BE3C8)
0 nil

 

如果有錯誤,會返回nil的錯誤語句。下面一個簡單的錯誤語句如下所示。

 

復制代碼 代碼如下:
LuaSQL: Error executing query. MySQL: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '"id INTEGER, name TEXT)' at line 1

 

Insert語句的例子

MySQL的INSERT語句如下所示。

 

復制代碼 代碼如下:
conn:execute([[INSERT INTO sample values('11','Raj')]])

 

Update語句的例子

對于MySQL UPDATE語句如下所示。

 

復制代碼 代碼如下:
conn:execute([[UPDATE sample3 SET name='John' where id ='12']])

 

刪除Delete 語句的例子

DELETE語句-MySQL如下所示。

 

復制代碼 代碼如下:
conn:execute([[DELETE from sample3 where id ='12']])

 

Select語句的例子

就select語句而言,我們需要遍歷每一行,并提取所需的數據。下面簡單的SELECT語句如下所示。

 

復制代碼 代碼如下:
cursor,errorString = conn:execute([[select * from sample]])
row = cursor:fetch ({}, "a")
while row do
  print(string.format("Id: %s, Name: %s", row.id, row.name))
  -- reusing the table of results
  row = cursor:fetch (row, "a")
end

 

在上面的代碼中,conn 是一個開放的MySQL連接。由執行語句返回游標,可以通過表的反應返回獲取所需的選擇數據。
一個完整的例子

所有上述聲明一個完整的例子給出下面的參考。

 

復制代碼 代碼如下:
mysql = require "luasql.mysql"

 

local env  = mysql.mysql()
local conn = env:connect('test','root','123456')
print(env,conn)

status,errorString = conn:execute([[CREATE TABLE sample3 (id INTEGER, name TEXT)]])
print(status,errorString )

status,errorString = conn:execute([[INSERT INTO sample3 values('12','Raj')]])
print(status,errorString )

cursor,errorString = conn:execute([[select * from sample3]])
print(cursor,errorString)

row = cursor:fetch ({}, "a")
while row do
  print(string.format("Id: %s, Name: %s", row.id, row.name))
  row = cursor:fetch (row, "a")
end
-- close everything
cursor:close()
conn:close()
env:close()

 

當運行上面的程序,會得到如下的輸出。

 

復制代碼 代碼如下:
MySQL environment (0037B178) MySQL connection (0037EBA8)
0 nil
1 nil
MySQL cursor (003778A8) nil
Id: 12, Name: Raj

 

執行事務:

事務是確保數據一致性的機制。事務應該具有以下四個特性:

  •     原子性:事務要么都完成或都沒有任何變化發生。
  •     一致性:事務必須啟動一個一致的狀態,讓系統處于一致的狀態。
  •     隔離:一個事務的中間結果是不是當前事務外可見。
  •     持久性:當一個事務被提交,這個效果是持久的,即使在系統出現故障。

事務開始START TRANSACTION;和commit或rollback語句結束。
開始事務

為了啟動一個事務,我們需要執行在Lua下面執行語句,假設conn是一個開放的MySQL連接。

 

復制代碼 代碼如下:
conn:execute([[START TRANSACTION;]])

 

回滾事務

 

我們需要做執行下面的語句來回滾執行開始事務后所做的更改。

 

復制代碼 代碼如下:
conn:execute([[ROLLBACK;]])

 

提交事務

我們需要做執行以下語句提交執行開始事務后所做的更改。

 

復制代碼 代碼如下:
conn:execute([[COMMIT;]])

 

我們已經在上面知道關于MySQL和下節介紹基本的SQL操作。請記住事務,但sqlite3不會再解釋了,但相同的語句在sqlite3也能正常工作。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
在线日韩中文字幕| 久久精品99无色码中文字幕| 欧美精品电影在线| 日韩a**中文字幕| 久久精品久久久久久国产 免费| 91av在线视频观看| 这里只有精品在线观看| 亚洲iv一区二区三区| 久久久国产在线视频| 久久深夜福利免费观看| xxxxxxxxx欧美| 日本一区二区在线播放| 国产91免费看片| 欧美激情亚洲另类| 久久中文字幕视频| 久久久国产一区| 亚洲人精品午夜在线观看| 亚洲精品在线91| 色www亚洲国产张柏芝| 欧美大片大片在线播放| 国产精品美女久久久免费| 韩国国内大量揄拍精品视频| 97人人模人人爽人人喊中文字| 一本一道久久a久久精品逆3p| 国产成人一区二区| 综合欧美国产视频二区| 日本精品va在线观看| 欧美精品在线免费观看| 国产成人精品久久二区二区91| 91精品国产综合久久香蕉最新版| 精品偷拍一区二区三区在线看| 日韩精品中文字幕视频在线| 色无极亚洲影院| 91国产视频在线| 久久人人97超碰精品888| 91精品中国老女人| 日本一本a高清免费不卡| 97视频免费观看| 久久亚洲精品国产亚洲老地址| 欧美日韩国产999| 久久最新资源网| 国产精品精品久久久久久| 国产91在线播放九色快色| 久久国产精品久久久久久| 成人精品在线观看| 精品久久中文字幕久久av| 色系列之999| 亚洲国产成人精品久久久国产成人一区| 日本精品va在线观看| 国产日韩精品在线播放| 成人免费看吃奶视频网站| 亚洲一区二区三区成人在线视频精品| 国产精品美腿一区在线看| 亚洲精品理论电影| 久久精品精品电影网| 最近2019中文免费高清视频观看www99| 色综合男人天堂| 亚洲第一色中文字幕| 亚洲欧美中文字幕在线一区| 成人av在线天堂| 91精品国产综合久久香蕉| 亚洲欧美制服综合另类| 精品国产欧美一区二区三区成人| 国产一区二区三区精品久久久| 国产精品wwww| 久久久国产一区| 久久欧美在线电影| 国产v综合ⅴ日韩v欧美大片| 欧美大片大片在线播放| 成人黄色影片在线| 国产欧亚日韩视频| 日韩一区二区av| 日韩欧美精品中文字幕| 正在播放国产一区| 91精品国产自产在线老师啪| 久久天天躁夜夜躁狠狠躁2022| 日韩欧美中文免费| 91国产视频在线播放| 性夜试看影院91社区| 亚洲成在人线av| 97在线免费观看| 国产成人精品国内自产拍免费看| 一二美女精品欧洲| 精品国产拍在线观看| 欧美激情中文字幕在线| 欧美激情精品久久久久| 日本免费一区二区三区视频观看| 97在线看免费观看视频在线观看| 亚洲毛片在线看| 欧美洲成人男女午夜视频| 国产一区二区三区在线| 91亚洲精品久久久| 亚洲国产高清福利视频| 最近2019中文字幕一页二页| 久久香蕉精品香蕉| 日韩视频永久免费观看| 亚洲视频999| 奇门遁甲1982国语版免费观看高清| 精品视频在线观看日韩| 色在人av网站天堂精品| 日本最新高清不卡中文字幕| 亚洲美女又黄又爽在线观看| 一本色道久久88综合日韩精品| 欧美激情va永久在线播放| 成人在线国产精品| 日韩精品在线看| 国产精品美女视频网站| 国产第一区电影| 日本精品视频在线观看| 日韩精品视频在线| 国产ts一区二区| 国产在线观看91精品一区| 97国产一区二区精品久久呦| 韩国19禁主播vip福利视频| 青草青草久热精品视频在线网站| 欧美精品videosex极品1| 精品久久久香蕉免费精品视频| 日韩av影院在线观看| 亚洲国产日韩欧美综合久久| 国产va免费精品高清在线观看| 成人免费视频网址| 日韩有码在线电影| 久久天天躁日日躁| 日本sm极度另类视频| 久久久久久国产免费| 日本精品一区二区三区在线| 成人午夜在线视频一区| 久久久久久欧美| 亚洲加勒比久久88色综合| 欧美性猛交xxxx乱大交3| 亚洲综合一区二区不卡| 久久久www成人免费精品| 性色av一区二区三区免费| 欧美精品激情视频| 午夜精品美女自拍福到在线| 午夜欧美不卡精品aaaaa| 欧美在线观看一区二区三区| 国产欧美精品日韩| 亚洲精品福利免费在线观看| 欧美华人在线视频| 美女精品久久久| 欧美一级黄色网| 日本久久久久久久久| 国产原创欧美精品| 亚洲成人av中文字幕| 国产精品久久久久久婷婷天堂| 亚洲一区亚洲二区亚洲三区| 欧美亚洲免费电影| 国产视频精品久久久| 国产美女精品视频免费观看| 亚洲国产精品人久久电影| 91九色国产社区在线观看| 欧美黑人极品猛少妇色xxxxx| 日本一本a高清免费不卡| 日韩在线中文字幕| 欧美成人免费播放| 亚洲第一区第一页| 亚洲欧美国产一本综合首页| 欧美一区二区视频97| 久久久久这里只有精品| 日本国产高清不卡| 日韩欧美亚洲范冰冰与中字| 日韩高清有码在线| xxx欧美精品|