1. 程式人生 > 其它 >Node-RED中連線Mysql資料庫並實現增刪改查的操作

Node-RED中連線Mysql資料庫並實現增刪改查的操作

場景

Node-RED中建立靜態網頁和動態網頁內容:

https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/124211653

在上面的基礎上,怎樣實現連線Mysql資料庫並將資料庫中的資料顯示在網頁上,以及執行插入、更新、刪除操作。

注:

部落格:
https://blog.csdn.net/badao_liumang_qizhi
關注公眾號
霸道的程式猿
獲取程式設計相關電子書、教程推送與免費下載。

實現

1、安裝NodeRED節點

節點管理搜尋node-red-node-mysql,安裝

 

 

安裝成功之後就會有Mysql節點了

 

 

2、資料庫設計一個測試的使用者表

流程設計如下

 

 

編輯function節點,使其執行查詢語句

msg.topic = "SELECT * FROM user";
return msg;

 

 

 

3、編輯Mysql節點

 

 

編輯連線輸入資料庫連線資訊

 

 

4、編輯template節點修改html顯示模板

<html>
    <head>
        <title>使用者</title>
    </head>
    <body>
      <table border="1
"> {{#payload}} <tr><td>{{name}}</td><td>{{pass}}</td></tr> {{/payload}} </table> </body> </html>

 

 

 

5、部署執行訪問

http://127.0.0.1:1880/allUser

 

 

6、查詢流程json資料

[
    {
        "id": "f4a4d8eab7935bc8",
        "type": "
tab", "label": "流程 3", "disabled": false, "info": "", "env": [] }, { "id": "c428312d1f6165d1", "type": "mqtt-broker", "name": "mqtt", "broker": "127.0.0.1", "port": "1883", "clientid": "", "autoConnect": true, "usetls": false, "protocolVersion": "4", "keepalive": "60", "cleansession": true, "birthTopic": "", "birthQos": "0", "birthPayload": "", "birthMsg": {}, "closeTopic": "", "closeQos": "0", "closePayload": "", "closeMsg": {}, "willTopic": "", "willQos": "0", "willPayload": "", "willMsg": {}, "sessionExpiry": "" }, { "id": "51eee50b4ec9422f", "type": "ui_group", "name": "dashboardDemo", "tab": "29ae4c620f43ee0d", "order": 1, "disp": true, "width": "6", "collapse": false, "className": "" }, { "id": "29ae4c620f43ee0d", "type": "ui_tab", "name": "Home", "icon": "dashboard", "disabled": false, "hidden": false }, { "id": "a506c767a5c1edbd", "type": "ui_base", "theme": { "name": "theme-light", "lightTheme": { "default": "#0094CE", "baseColor": "#0094CE", "baseFont": "-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen-Sans,Ubuntu,Cantarell,Helvetica Neue,sans-serif", "edited": true, "reset": false }, "darkTheme": { "default": "#097479", "baseColor": "#097479", "baseFont": "-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen-Sans,Ubuntu,Cantarell,Helvetica Neue,sans-serif", "edited": false }, "customTheme": { "name": "Untitled Theme 1", "default": "#4B7930", "baseColor": "#4B7930", "baseFont": "-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen-Sans,Ubuntu,Cantarell,Helvetica Neue,sans-serif" }, "themeState": { "base-color": { "default": "#0094CE", "value": "#0094CE", "edited": false }, "page-titlebar-backgroundColor": { "value": "#0094CE", "edited": false }, "page-backgroundColor": { "value": "#fafafa", "edited": false }, "page-sidebar-backgroundColor": { "value": "#ffffff", "edited": false }, "group-textColor": { "value": "#1bbfff", "edited": false }, "group-borderColor": { "value": "#ffffff", "edited": false }, "group-backgroundColor": { "value": "#ffffff", "edited": false }, "widget-textColor": { "value": "#111111", "edited": false }, "widget-backgroundColor": { "value": "#0094ce", "edited": false }, "widget-borderColor": { "value": "#ffffff", "edited": false }, "base-font": { "value": "-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen-Sans,Ubuntu,Cantarell,Helvetica Neue,sans-serif" } }, "angularTheme": { "primary": "indigo", "accents": "blue", "warn": "red", "background": "grey", "palette": "light" } }, "site": { "name": "Node-RED Dashboard", "hideToolbar": "false", "allowSwipe": "false", "lockMenu": "false", "allowTempTheme": "true", "dateFormat": "DD/MM/YYYY", "sizes": { "sx": 48, "sy": 48, "gx": 6, "gy": 6, "cx": 6, "cy": 6, "px": 0, "py": 0 } } }, { "id": "248cbbb0.18e794", "type": "ui_group", "name": "MyGroup", "tab": "3f79c420.cfc1bc", "order": 1, "disp": true, "width": "6", "collapse": false }, { "id": "3f79c420.cfc1bc", "type": "ui_tab", "name": "Home", "icon": "dashboard", "disabled": false, "hidden": false }, { "id": "a0954be5.a7f7e8", "type": "ui_group", "name": "MyInput", "tab": "3f79c420.cfc1bc", "order": 2, "disp": true, "width": "6", "collapse": false }, { "id": "508bd6f8398ab80f", "type": "ui_group", "name": "OpenWeatherMap", "tab": "3f79c420.cfc1bc", "order": 3, "disp": true, "width": "6", "collapse": false }, { "id": "8824dea1.83e31", "type": "websocket-client", "path": "ws://localhost:9898/", "tls": "", "wholemsg": "false" }, { "id": "51c3503.61936b", "type": "MySQLdatabase", "name": "", "host": "127.0.0.1", "port": "3306", "db": "test", "tz": "", "charset": "UTF8" }, { "id": "571a8ee8.5883d", "type": "http in", "z": "f4a4d8eab7935bc8", "name": "", "url": "/allUser", "method": "get", "upload": false, "swaggerDoc": "", "x": 210, "y": 160, "wires": [ [ "71ec3368.c3cf5c" ] ] }, { "id": "7eb81f73.1710c", "type": "template", "z": "f4a4d8eab7935bc8", "name": "HTML網頁", "field": "payload", "fieldType": "msg", "format": "handlebars", "syntax": "mustache", "template": "<html>\n <head>\n <title>使用者</title>\n </head>\n <body>\n <table border=\"1\">\n {{#payload}}\n <tr><td>{{name}}</td><td>{{pass}}</td></tr>\n {{/payload}}\n </table>\n </body>\n</html>", "x": 570, "y": 160, "wires": [ [ "766f42f9.87fbcc" ] ] }, { "id": "71ec3368.c3cf5c", "type": "function", "z": "f4a4d8eab7935bc8", "name": "SQL Query", "func": "msg.topic = \"SELECT * FROM user\";\nreturn msg;", "outputs": 1, "noerr": 0, "initialize": "", "finalize": "", "libs": [], "x": 290, "y": 240, "wires": [ [ "1c7d1dcf.bb2ad2" ] ] }, { "id": "766f42f9.87fbcc", "type": "http response", "z": "f4a4d8eab7935bc8", "name": "", "statusCode": "", "headers": {}, "x": 610, "y": 240, "wires": [] }, { "id": "1c7d1dcf.bb2ad2", "type": "mysql", "z": "f4a4d8eab7935bc8", "mydb": "51c3503.61936b", "name": "", "x": 410, "y": 160, "wires": [ [ "7eb81f73.1710c" ] ] } ]

 

7、實現插入操作

新增插入資料的流程設計

 

 

編輯function節點,編輯插入語句

 

 

執行檢視效果

 

 

插入流程json資料

[
    {
        "id": "1d9518ddb606e944",
        "type": "inject",
        "z": "f4a4d8eab7935bc8",
        "name": "",
        "props": [
            {
                "p": "payload"
            },
            {
                "p": "topic",
                "vt": "str"
            }
        ],
        "repeat": "",
        "crontab": "",
        "once": false,
        "onceDelay": 0.1,
        "topic": "",
        "payloadType": "date",
        "x": 210,
        "y": 380,
        "wires": [
            [
                "e28fd0d0403014e0"
            ]
        ]
    },
    {
        "id": "e28fd0d0403014e0",
        "type": "function",
        "z": "f4a4d8eab7935bc8",
        "name": "INSERT",
        "func": "\nvar user = 'insertUser';\nvar pass = '123456';\n\nmsg.topic = \"INSERT INTO user \" +\n     \"(name,pass)\" +\n     \"VALUES ('\" + user +\n     \"','\"+ pass + \"' )\";\nreturn msg;",
        "outputs": 1,
        "noerr": 0,
        "initialize": "",
        "finalize": "",
        "libs": [],
        "x": 340,
        "y": 380,
        "wires": [
            [
                "fdde79cf9a1b1722"
            ]
        ]
    },
    {
        "id": "fdde79cf9a1b1722",
        "type": "mysql",
        "z": "f4a4d8eab7935bc8",
        "mydb": "51c3503.61936b",
        "name": "",
        "x": 480,
        "y": 380,
        "wires": [
            [
                "5ea56f3eec020d0f"
            ]
        ]
    },
    {
        "id": "5ea56f3eec020d0f",
        "type": "debug",
        "z": "f4a4d8eab7935bc8",
        "name": "",
        "active": true,
        "tosidebar": true,
        "console": false,
        "tostatus": false,
        "complete": "payload",
        "targetType": "msg",
        "statusVal": "",
        "statusType": "auto",
        "x": 630,
        "y": 380,
        "wires": []
    },
    {
        "id": "51c3503.61936b",
        "type": "MySQLdatabase",
        "name": "",
        "host": "127.0.0.1",
        "port": "3306",
        "db": "test",
        "tz": "",
        "charset": "UTF8",
        "credentials": {}
    }
]

 

8、新增更新語句執行流程設計如下

 

 

模板值可以在字元找那個嵌入運算式或變數。

但是注意的是字串是使用反引號,在Tab上方的按鈕括起,而不是使用單引號括起。

編輯function節點

var id = 3;
var name = 'updateName';
var pass = '5555';
msg.topic = `UPDATE user SET name='${name}',` +
            `pass='${pass}' WHERE id=${id}`;
return msg;

 

 

 

部署執行看效果

 

 

更新流程json資料

[
    {
        "id": "5426aed100d65d31",
        "type": "inject",
        "z": "f4a4d8eab7935bc8",
        "name": "",
        "repeat": "",
        "crontab": "",
        "once": false,
        "onceDelay": 0.1,
        "topic": "",
        "payload": "",
        "payloadType": "date",
        "x": 210,
        "y": 520,
        "wires": [
            [
                "a911307ea6b68a16"
            ]
        ]
    },
    {
        "id": "a911307ea6b68a16",
        "type": "function",
        "z": "f4a4d8eab7935bc8",
        "name": "UPDATE",
        "func": "var id = 3;\nvar name = 'updateName';\nvar pass = '5555';\nmsg.topic = `UPDATE user SET name='${name}',` +\n            `pass='${pass}' WHERE id=${id}`;\nreturn msg;",
        "outputs": 1,
        "noerr": 0,
        "initialize": "",
        "finalize": "",
        "libs": [],
        "x": 340,
        "y": 520,
        "wires": [
            [
                "eb4b3bd2a53dbb37",
                "d991b7f159d90812"
            ]
        ]
    },
    {
        "id": "eb4b3bd2a53dbb37",
        "type": "mysql",
        "z": "f4a4d8eab7935bc8",
        "mydb": "51c3503.61936b",
        "name": "",
        "x": 480,
        "y": 520,
        "wires": [
            [
                "c83545834bc01135"
            ]
        ]
    },
    {
        "id": "c83545834bc01135",
        "type": "debug",
        "z": "f4a4d8eab7935bc8",
        "name": "",
        "active": true,
        "tosidebar": true,
        "console": false,
        "tostatus": false,
        "complete": "payload",
        "targetType": "msg",
        "statusVal": "",
        "statusType": "auto",
        "x": 630,
        "y": 520,
        "wires": []
    },
    {
        "id": "d991b7f159d90812",
        "type": "debug",
        "z": "f4a4d8eab7935bc8",
        "name": "",
        "active": true,
        "tosidebar": true,
        "console": false,
        "tostatus": false,
        "complete": "topic",
        "targetType": "msg",
        "statusVal": "",
        "statusType": "auto",
        "x": 480,
        "y": 600,
        "wires": []
    },
    {
        "id": "51c3503.61936b",
        "type": "MySQLdatabase",
        "name": "",
        "host": "127.0.0.1",
        "port": "3306",
        "db": "test",
        "tz": "",
        "charset": "UTF8"
    }
]

 

9、設計刪除流程佈局

 

 

編輯template節點

DELETE FROM user WHERE id='{{payload}}'

 

 

 

部署執行檢視效果

 

 

 

 

刪除流程json資料

 

[
    {
        "id": "883fb789f22f352f",
        "type": "inject",
        "z": "f4a4d8eab7935bc8",
        "name": "",
        "props": [
            {
                "p": "payload"
            },
            {
                "p": "topic",
                "vt": "str"
            }
        ],
        "repeat": "",
        "crontab": "",
        "once": false,
        "onceDelay": 0.1,
        "topic": "",
        "payload": "1",
        "payloadType": "str",
        "x": 210,
        "y": 720,
        "wires": [
            [
                "15479540478f4720"
            ]
        ]
    },
    {
        "id": "fd30c40a7a9d0baf",
        "type": "mysql",
        "z": "f4a4d8eab7935bc8",
        "mydb": "51c3503.61936b",
        "name": "",
        "x": 480,
        "y": 720,
        "wires": [
            [
                "6eb37dd7c809dd01"
            ]
        ]
    },
    {
        "id": "6eb37dd7c809dd01",
        "type": "debug",
        "z": "f4a4d8eab7935bc8",
        "name": "",
        "active": true,
        "tosidebar": true,
        "console": false,
        "tostatus": false,
        "complete": "payload",
        "targetType": "msg",
        "statusVal": "",
        "statusType": "auto",
        "x": 630,
        "y": 720,
        "wires": []
    },
    {
        "id": "15479540478f4720",
        "type": "template",
        "z": "f4a4d8eab7935bc8",
        "name": "DELETE",
        "field": "topic",
        "fieldType": "msg",
        "format": "handlebars",
        "syntax": "mustache",
        "template": "DELETE FROM user WHERE id='{{payload}}'",
        "output": "str",
        "x": 340,
        "y": 720,
        "wires": [
            [
                "fd30c40a7a9d0baf"
            ]
        ]
    },
    {
        "id": "51c3503.61936b",
        "type": "MySQLdatabase",
        "name": "",
        "host": "127.0.0.1",
        "port": "3306",
        "db": "test",
        "tz": "",
        "charset": "UTF8"
    }
]

 

10、增刪改查全流程json資料

[
    {
        "id": "f4a4d8eab7935bc8",
        "type": "tab",
        "label": "流程 3",
        "disabled": false,
        "info": "",
        "env": []
    },
    {
        "id": "c428312d1f6165d1",
        "type": "mqtt-broker",
        "name": "mqtt",
        "broker": "127.0.0.1",
        "port": "1883",
        "clientid": "",
        "autoConnect": true,
        "usetls": false,
        "protocolVersion": "4",
        "keepalive": "60",
        "cleansession": true,
        "birthTopic": "",
        "birthQos": "0",
        "birthPayload": "",
        "birthMsg": {},
        "closeTopic": "",
        "closeQos": "0",
        "closePayload": "",
        "closeMsg": {},
        "willTopic": "",
        "willQos": "0",
        "willPayload": "",
        "willMsg": {},
        "sessionExpiry": ""
    },
    {
        "id": "51eee50b4ec9422f",
        "type": "ui_group",
        "name": "dashboardDemo",
        "tab": "29ae4c620f43ee0d",
        "order": 1,
        "disp": true,
        "width": "6",
        "collapse": false,
        "className": ""
    },
    {
        "id": "29ae4c620f43ee0d",
        "type": "ui_tab",
        "name": "Home",
        "icon": "dashboard",
        "disabled": false,
        "hidden": false
    },
    {
        "id": "a506c767a5c1edbd",
        "type": "ui_base",
        "theme": {
            "name": "theme-light",
            "lightTheme": {
                "default": "#0094CE",
                "baseColor": "#0094CE",
                "baseFont": "-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen-Sans,Ubuntu,Cantarell,Helvetica Neue,sans-serif",
                "edited": true,
                "reset": false
            },
            "darkTheme": {
                "default": "#097479",
                "baseColor": "#097479",
                "baseFont": "-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen-Sans,Ubuntu,Cantarell,Helvetica Neue,sans-serif",
                "edited": false
            },
            "customTheme": {
                "name": "Untitled Theme 1",
                "default": "#4B7930",
                "baseColor": "#4B7930",
                "baseFont": "-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen-Sans,Ubuntu,Cantarell,Helvetica Neue,sans-serif"
            },
            "themeState": {
                "base-color": {
                    "default": "#0094CE",
                    "value": "#0094CE",
                    "edited": false
                },
                "page-titlebar-backgroundColor": {
                    "value": "#0094CE",
                    "edited": false
                },
                "page-backgroundColor": {
                    "value": "#fafafa",
                    "edited": false
                },
                "page-sidebar-backgroundColor": {
                    "value": "#ffffff",
                    "edited": false
                },
                "group-textColor": {
                    "value": "#1bbfff",
                    "edited": false
                },
                "group-borderColor": {
                    "value": "#ffffff",
                    "edited": false
                },
                "group-backgroundColor": {
                    "value": "#ffffff",
                    "edited": false
                },
                "widget-textColor": {
                    "value": "#111111",
                    "edited": false
                },
                "widget-backgroundColor": {
                    "value": "#0094ce",
                    "edited": false
                },
                "widget-borderColor": {
                    "value": "#ffffff",
                    "edited": false
                },
                "base-font": {
                    "value": "-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen-Sans,Ubuntu,Cantarell,Helvetica Neue,sans-serif"
                }
            },
            "angularTheme": {
                "primary": "indigo",
                "accents": "blue",
                "warn": "red",
                "background": "grey",
                "palette": "light"
            }
        },
        "site": {
            "name": "Node-RED Dashboard",
            "hideToolbar": "false",
            "allowSwipe": "false",
            "lockMenu": "false",
            "allowTempTheme": "true",
            "dateFormat": "DD/MM/YYYY",
            "sizes": {
                "sx": 48,
                "sy": 48,
                "gx": 6,
                "gy": 6,
                "cx": 6,
                "cy": 6,
                "px": 0,
                "py": 0
            }
        }
    },
    {
        "id": "248cbbb0.18e794",
        "type": "ui_group",
        "name": "MyGroup",
        "tab": "3f79c420.cfc1bc",
        "order": 1,
        "disp": true,
        "width": "6",
        "collapse": false
    },
    {
        "id": "3f79c420.cfc1bc",
        "type": "ui_tab",
        "name": "Home",
        "icon": "dashboard",
        "disabled": false,
        "hidden": false
    },
    {
        "id": "a0954be5.a7f7e8",
        "type": "ui_group",
        "name": "MyInput",
        "tab": "3f79c420.cfc1bc",
        "order": 2,
        "disp": true,
        "width": "6",
        "collapse": false
    },
    {
        "id": "508bd6f8398ab80f",
        "type": "ui_group",
        "name": "OpenWeatherMap",
        "tab": "3f79c420.cfc1bc",
        "order": 3,
        "disp": true,
        "width": "6",
        "collapse": false
    },
    {
        "id": "8824dea1.83e31",
        "type": "websocket-client",
        "path": "ws://localhost:9898/",
        "tls": "",
        "wholemsg": "false"
    },
    {
        "id": "51c3503.61936b",
        "type": "MySQLdatabase",
        "name": "",
        "host": "127.0.0.1",
        "port": "3306",
        "db": "test",
        "tz": "",
        "charset": "UTF8"
    },
    {
        "id": "571a8ee8.5883d",
        "type": "http in",
        "z": "f4a4d8eab7935bc8",
        "name": "",
        "url": "/allUser",
        "method": "get",
        "upload": false,
        "swaggerDoc": "",
        "x": 210,
        "y": 160,
        "wires": [
            [
                "71ec3368.c3cf5c"
            ]
        ]
    },
    {
        "id": "7eb81f73.1710c",
        "type": "template",
        "z": "f4a4d8eab7935bc8",
        "name": "HTML網頁",
        "field": "payload",
        "fieldType": "msg",
        "format": "handlebars",
        "syntax": "mustache",
        "template": "<html>\n    <head>\n        <title>使用者</title>\n    </head>\n    <body>\n      <table border=\"1\">\n       {{#payload}}\n          <tr><td>{{name}}</td><td>{{pass}}</td></tr>\n       {{/payload}}\n      </table>\n    </body>\n</html>",
        "x": 570,
        "y": 160,
        "wires": [
            [
                "766f42f9.87fbcc"
            ]
        ]
    },
    {
        "id": "71ec3368.c3cf5c",
        "type": "function",
        "z": "f4a4d8eab7935bc8",
        "name": "SQL Query",
        "func": "msg.topic = \"SELECT * FROM user\";\nreturn msg;",
        "outputs": 1,
        "noerr": 0,
        "initialize": "",
        "finalize": "",
        "libs": [],
        "x": 290,
        "y": 240,
        "wires": [
            [
                "1c7d1dcf.bb2ad2"
            ]
        ]
    },
    {
        "id": "766f42f9.87fbcc",
        "type": "http response",
        "z": "f4a4d8eab7935bc8",
        "name": "",
        "statusCode": "",
        "headers": {},
        "x": 610,
        "y": 240,
        "wires": []
    },
    {
        "id": "1c7d1dcf.bb2ad2",
        "type": "mysql",
        "z": "f4a4d8eab7935bc8",
        "mydb": "51c3503.61936b",
        "name": "",
        "x": 410,
        "y": 160,
        "wires": [
            [
                "7eb81f73.1710c"
            ]
        ]
    },
    {
        "id": "1d9518ddb606e944",
        "type": "inject",
        "z": "f4a4d8eab7935bc8",
        "name": "",
        "props": [
            {
                "p": "payload"
            },
            {
                "p": "topic",
                "vt": "str"
            }
        ],
        "repeat": "",
        "crontab": "",
        "once": false,
        "onceDelay": 0.1,
        "topic": "",
        "payloadType": "date",
        "x": 210,
        "y": 380,
        "wires": [
            [
                "e28fd0d0403014e0"
            ]
        ]
    },
    {
        "id": "e28fd0d0403014e0",
        "type": "function",
        "z": "f4a4d8eab7935bc8",
        "name": "INSERT",
        "func": "\nvar user = 'insertUser';\nvar pass = '123456';\n\nmsg.topic = \"INSERT INTO user \" +\n     \"(name,pass)\" +\n     \"VALUES ('\" + user +\n     \"','\"+ pass + \"' )\";\nreturn msg;",
        "outputs": 1,
        "noerr": 0,
        "initialize": "",
        "finalize": "",
        "libs": [],
        "x": 340,
        "y": 380,
        "wires": [
            [
                "fdde79cf9a1b1722"
            ]
        ]
    },
    {
        "id": "fdde79cf9a1b1722",
        "type": "mysql",
        "z": "f4a4d8eab7935bc8",
        "mydb": "51c3503.61936b",
        "name": "",
        "x": 480,
        "y": 380,
        "wires": [
            [
                "5ea56f3eec020d0f"
            ]
        ]
    },
    {
        "id": "5ea56f3eec020d0f",
        "type": "debug",
        "z": "f4a4d8eab7935bc8",
        "name": "",
        "active": true,
        "tosidebar": true,
        "console": false,
        "tostatus": false,
        "complete": "payload",
        "targetType": "msg",
        "statusVal": "",
        "statusType": "auto",
        "x": 630,
        "y": 380,
        "wires": []
    },
    {
        "id": "5426aed100d65d31",
        "type": "inject",
        "z": "f4a4d8eab7935bc8",
        "name": "",
        "repeat": "",
        "crontab": "",
        "once": false,
        "onceDelay": 0.1,
        "topic": "",
        "payload": "",
        "payloadType": "date",
        "x": 210,
        "y": 520,
        "wires": [
            [
                "a911307ea6b68a16"
            ]
        ]
    },
    {
        "id": "a911307ea6b68a16",
        "type": "function",
        "z": "f4a4d8eab7935bc8",
        "name": "UPDATE",
        "func": "var id = 3;\nvar name = 'updateName';\nvar pass = '5555';\nmsg.topic = `UPDATE user SET name='${name}',` +\n            `pass='${pass}' WHERE id=${id}`;\nreturn msg;",
        "outputs": 1,
        "noerr": 0,
        "initialize": "",
        "finalize": "",
        "libs": [],
        "x": 340,
        "y": 520,
        "wires": [
            [
                "eb4b3bd2a53dbb37",
                "d991b7f159d90812"
            ]
        ]
    },
    {
        "id": "eb4b3bd2a53dbb37",
        "type": "mysql",
        "z": "f4a4d8eab7935bc8",
        "mydb": "51c3503.61936b",
        "name": "",
        "x": 480,
        "y": 520,
        "wires": [
            [
                "c83545834bc01135"
            ]
        ]
    },
    {
        "id": "c83545834bc01135",
        "type": "debug",
        "z": "f4a4d8eab7935bc8",
        "name": "",
        "active": true,
        "tosidebar": true,
        "console": false,
        "tostatus": false,
        "complete": "payload",
        "targetType": "msg",
        "statusVal": "",
        "statusType": "auto",
        "x": 630,
        "y": 520,
        "wires": []
    },
    {
        "id": "d991b7f159d90812",
        "type": "debug",
        "z": "f4a4d8eab7935bc8",
        "name": "",
        "active": true,
        "tosidebar": true,
        "console": false,
        "tostatus": false,
        "complete": "topic",
        "targetType": "msg",
        "statusVal": "",
        "statusType": "auto",
        "x": 480,
        "y": 600,
        "wires": []
    },
    {
        "id": "883fb789f22f352f",
        "type": "inject",
        "z": "f4a4d8eab7935bc8",
        "name": "",
        "props": [
            {
                "p": "payload"
            },
            {
                "p": "topic",
                "vt": "str"
            }
        ],
        "repeat": "",
        "crontab": "",
        "once": false,
        "onceDelay": 0.1,
        "topic": "",
        "payload": "1",
        "payloadType": "str",
        "x": 210,
        "y": 720,
        "wires": [
            [
                "15479540478f4720"
            ]
        ]
    },
    {
        "id": "fd30c40a7a9d0baf",
        "type": "mysql",
        "z": "f4a4d8eab7935bc8",
        "mydb": "51c3503.61936b",
        "name": "",
        "x": 480,
        "y": 720,
        "wires": [
            [
                "6eb37dd7c809dd01"
            ]
        ]
    },
    {
        "id": "6eb37dd7c809dd01",
        "type": "debug",
        "z": "f4a4d8eab7935bc8",
        "name": "",
        "active": true,
        "tosidebar": true,
        "console": false,
        "tostatus": false,
        "complete": "payload",
        "targetType": "msg",
        "statusVal": "",
        "statusType": "auto",
        "x": 630,
        "y": 720,
        "wires": []
    },
    {
        "id": "15479540478f4720",
        "type": "template",
        "z": "f4a4d8eab7935bc8",
        "name": "DELETE",
        "field": "topic",
        "fieldType": "msg",
        "format": "handlebars",
        "syntax": "mustache",
        "template": "DELETE FROM user WHERE id='{{payload}}'",
        "output": "str",
        "x": 340,
        "y": 720,
        "wires": [
            [
                "fd30c40a7a9d0baf"
            ]
        ]
    }
]