項目4任務(wù)5-Node-RED 對MySQL數(shù)據(jù)庫的增刪改查_第1頁
項目4任務(wù)5-Node-RED 對MySQL數(shù)據(jù)庫的增刪改查_第2頁
項目4任務(wù)5-Node-RED 對MySQL數(shù)據(jù)庫的增刪改查_第3頁
項目4任務(wù)5-Node-RED 對MySQL數(shù)據(jù)庫的增刪改查_第4頁
項目4任務(wù)5-Node-RED 對MySQL數(shù)據(jù)庫的增刪改查_第5頁
已閱讀5頁,還剩15頁未讀 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)

文檔簡介

2相關(guān)知識34任務(wù)小結(jié)與練習(xí)1任務(wù)實施任務(wù)引入與目標(biāo)Node-RED對MySQL數(shù)據(jù)庫的增刪改查一、任務(wù)引入與目標(biāo)任務(wù)引入數(shù)據(jù)庫最基本和常用的操作就是對數(shù)據(jù)表記錄的增刪改查。在Node-RED中該如何訪問MySQL中的數(shù)據(jù)庫,進(jìn)而對數(shù)據(jù)表中的記錄進(jìn)行增刪改查呢?任務(wù)目標(biāo)任務(wù)5將在MySQL里創(chuàng)建數(shù)據(jù)庫和數(shù)據(jù)表,通過Node-RED訪問數(shù)據(jù)庫,實現(xiàn)對數(shù)據(jù)表記錄的增刪改查,其中的關(guān)鍵是SQL語句語法。二、相關(guān)知識增加一條記錄的SQL語句語法:INSERTINTOtable_name(column1,column2,column3,...)VALUES(value1,value2,value3,...);功能是:插入一條記錄到表table_name中,值是value1,value2,value3,...。對應(yīng)字段為column1,column2,column3,...。刪除記錄的SQL語句語法:DELETEFROMtable_nameWHEREsome_column=some_value;功能是:當(dāng)滿足條件some_column=some_value時,從表table_name中刪除某條記錄。二、相關(guān)知識修改記錄的SQL語句語法:UPDATEtable_nameSETcolumn1=value1,column2=value2,...WHEREsome_column=some_value;功能是:當(dāng)滿足條件some_column=some_value時,修改table_name表中記錄column1字段的值為value1,column2字段的值為value2,以此類推。查詢表語法:SELECTcolumn1,column2FROMtable_name;功能是:查詢表中記錄的column1和column2列的值;可以使用WHERE語句來包含任何條件,可以使用LIMIT屬性來設(shè)定返回的記錄數(shù)。課堂討論SQL語句中的關(guān)鍵字區(qū)分大小寫嗎?三、任務(wù)實施實施設(shè)備部署了MySQL和Node-RED開發(fā)環(huán)境的計算機。實施過程1.新建數(shù)據(jù)庫和數(shù)據(jù)表新建數(shù)據(jù)庫和數(shù)據(jù)表在命令行和可視化管理軟件中均可完成。任務(wù)5以HeidiSQL為例講解。(1)創(chuàng)建數(shù)據(jù)庫node_red_test。創(chuàng)建新的數(shù)據(jù)庫node_red_test,如圖4-58所示。圖4-58創(chuàng)建數(shù)據(jù)庫三、任務(wù)實施(2)創(chuàng)建數(shù)據(jù)表student。如圖4-59所示,創(chuàng)建數(shù)據(jù)表,共四個字段:id、name、age、class。其中,id為自動增長。id設(shè)為主鍵,如圖4-60所示。圖4-59創(chuàng)建數(shù)據(jù)表圖4-60創(chuàng)建主鍵索引然后保存即可?,F(xiàn)在表中數(shù)據(jù)記錄顯示為0條記錄,如圖4-61所示。圖4-61student表的記錄三、任務(wù)實施2.配置Node-RED中的mysql節(jié)點啟動Node-RED。先在命令行輸入node-red,然后在瀏覽器輸入網(wǎng)址登錄::1880/。將mysql節(jié)點拖入流程中,如圖4-62所示,配置mysql節(jié)點。如圖4-63所示,如果信息正確,部署之后,就會發(fā)現(xiàn)數(shù)據(jù)庫node_red_test連接成功。圖4-62編輯mysql節(jié)點圖4-63成功連接到數(shù)據(jù)庫node_red_test三、任務(wù)實施3.通過mysql節(jié)點增加一條記錄如圖4-64所示,拖入一個inject節(jié)點和一個function節(jié)點,連接起來。其中,inject用于單次觸發(fā),function用于編寫數(shù)據(jù)庫操作的SQL語句。節(jié)點的配置如圖4-65所示。圖4-64增加一條記錄流程圖4-65編輯inject節(jié)點三、任務(wù)實施function節(jié)點實際上就是一個JavaScript代碼編輯器,在function節(jié)點的函數(shù)選項卡編輯msg的topic和payload,傳入下一節(jié)點(即node_red_test數(shù)據(jù)庫節(jié)點),如圖4-66所示。完整的SQL語句為:insertinto"student"("id","name","age","class")values(,"zhangsan",19,"IOT2101")。其中,id的值為空,因為id是自動增加的,可以不用賦值。完成后部署。點擊inject節(jié)點觸發(fā)一次,如圖4-67所示。圖4-66編輯function節(jié)點圖4-68數(shù)據(jù)表增加了一條記錄查看數(shù)據(jù)庫node_red_test中student表的數(shù)據(jù),增加了一條記錄,如圖4-68所示。圖4-67觸發(fā)inject節(jié)點三、任務(wù)實施按同樣的方法,增加3個inject和3個function節(jié)點,在數(shù)據(jù)表中增加3條記錄,如圖4-69所示。圖4-69增加4條記錄的流程圖4-70數(shù)據(jù)表中的4條記錄重新部署,新增加的3個inject節(jié)點各觸發(fā)一次。結(jié)果如圖4-70所示。三、任務(wù)實施4.通過mysql節(jié)點修改記錄假設(shè)剛才輸入的lisi的年齡錯了,不是20歲而是21歲。修改記錄的流程如圖4-71所示。圖4-71修改記錄的流程圖4-72編輯function節(jié)點如圖4-72所示,用SQL語句編輯function節(jié)點,語句為:update"student"set"age"=21where"name"="lisi"。三、任務(wù)實施部署之后,單擊inject節(jié)點左側(cè)的方框觸發(fā),如圖4-73所示。圖4-73觸發(fā)inject節(jié)點圖4-74修改數(shù)據(jù)表中的記錄結(jié)果如圖4-74所示,可見,lisi的age被修改成了21歲。三、任務(wù)實施5.通過mysql節(jié)點查詢數(shù)據(jù)表(1)查詢操作。在查詢操作之前,把上面2個mysql節(jié)點設(shè)置為無效,以節(jié)省資源。節(jié)點無效的方法:打開節(jié)點,在左下角點擊即可在“有效”和“無效”之間切換。節(jié)點無效之后,則變成半透明的。下面編輯流程,共4個節(jié)點,如圖4-75所示。如圖4-76所示編輯function節(jié)點,傳往下一個節(jié)點的消息為SQL語句:select*from"student"where"name"="lisi"。圖4-75查詢數(shù)據(jù)表的流程圖4-76編輯function節(jié)點三、任務(wù)實施部署之后,觸發(fā)。打印結(jié)果如圖4-77所示。因為只查詢到一條記錄,所以返回的列表(數(shù)組)中只有一個元素。這個唯一的索引為0的元素是JsonObject(JSON對象)格式的,由4個成員構(gòu)成。所以可能有人會問:“如何取出其班級值呢?”有了數(shù)組和JSON對象的知識,我們很容易可以寫出:msg.payload[0].class??梢栽赿ebug節(jié)點前增加一個function節(jié)點或change節(jié)點,獲取數(shù)據(jù)庫查詢的返回內(nèi)容并提取之后,在debug打印出來。(2)change節(jié)點解析。增加change節(jié)點,如圖4-78所示。圖4-77打印查詢結(jié)果圖4-78增加change節(jié)點三、任務(wù)實施change節(jié)點配置如圖4-79所示。部署并觸發(fā),觀察結(jié)果,如圖4-80所示。圖4-79編輯change節(jié)點圖4-80打印解析結(jié)果三、任務(wù)實施(3)function節(jié)點解析。增加function節(jié)點,如圖4-81所示。function節(jié)點配置,如圖4-82所示。圖4-81增加function節(jié)點圖4-82編輯function節(jié)點三、任務(wù)實施部署并觸發(fā),觀察結(jié)果,如圖4-83所示。6.通過mysql節(jié)點刪除記錄刪除name為wangwu的記錄,流程如圖4-84所示。圖4-83打印解析結(jié)果圖4-84刪除記錄流程三、任務(wù)實施如圖4-85所示,配置function節(jié)點,SQL語句為:delete

from"student"where"name"="wangwu"。部署并觸發(fā),如圖4-86所示。圖4-85編輯function節(jié)點圖4-87刪除一條記錄的結(jié)果查看結(jié)果,如圖4-87所示,wangwu的記錄已經(jīng)不在了。圖4-86流程運行結(jié)果四、任務(wù)小結(jié)與練習(xí)任務(wù)小結(jié)任務(wù)5通過Node-R

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論