2021-05-12 14:32:11
NodeJS+Express+MySQL 增刪改查
之前,一直使用的是nodejs+thinkjs來完成自己所需的專案需求,而對於nodejs中另外一中應用框架express卻了解的少之又少,這兩天就簡單的了解了一下如何使用express來做一些資料庫的增刪改查。
準備工作:
所需工具:電腦上要安裝好nodejs(官網https://nodejs.org/en/),下載並安裝好nodejs之後,需要在cmd中再安裝好express框架:
npm install express-generator -g
安裝完畢之後,檢查一下是否安裝成功:
還有一個工具就是連線資料庫操作的Navicat用戶端(我們平常連線資料庫的工具,挺好用的。)
準備好這些工具之後,就可以開始我們的資料庫操作了(記得電腦上也要裝上webstroms,這個就跳過不說了)。
著手demo:
1.開啟webstroms,新建一個express專案:
接著選擇好檔案型別:
在這裡,我選擇的是EJS模板引擎,這個憑自己喜好決定。於是新建好的專案目錄就是醬紫滴:
大家應該注意到了,views資料夾下的並非是平常所見的.html檔案,而是.ejs檔案,於是就需要我們自己來把它預設的引擎從EJS改成HTML,修改的操作就是開啟app.js檔案,然後將其中一段程式碼註釋掉並修改成如下:
// view engine setup // app.set('views', path.join(__dirname, 'views')); // app.set('view engine', 'ejs'); //注釋掉預設的,自己手動修改預設引擎 app.set('views', path.join(__dirname, 'views')); var template = require('art-template'); template.config('base', ''); template.config('extname', '.html'); app.engine('.html', template.__express); app.set('view engine', 'html');
然後將原有預設的兩個.ejs檔案刪掉,並建立相應的.html檔案,在這個小demo中,鑑於自己所需的,故重新建好的檔案目錄是醬紫滴:
2.資料庫準備:
開啟Navicat用戶端,新建一個資料庫,指令碼如下:
create database testdb; use testdb; create table userinfo( id int not null auto_increment, name varchar(20) not null, age int not null, primary key (id) )
這樣我們所需的資料庫就有了。
接著就是將專案和此資料庫連線起來——在剛才新建的db.js中,來實現連線資料庫:
//db.js
/** * Created by Administrator on 2016/7/19. */ // 連線MySQL var mysql = require('mysql'); var pool = mysql.createPool({ host: 'localhost', user: 'root', password: 'root', database: 'testdb' }); function query(sql, callback) { pool.getConnection(function (err, connection) { // Use the connection connection.query(sql, function (err, rows) { callback(err, rows); connection.release();//釋放連結 }); }); } exports.query = query;
我是將程式碼寫在users.js中,而預設的index中就都沒有寫任何程式碼,於是完整的程式碼如下:
①users.html:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>{{title}}</title> </head> <body> <form action="/users/search" method="post"> 姓名:<input type="text" name="s_name" value="{{s_name}}"><br> 年齡:<input type="text" name="s_age" value="{{s_age}}"><br> <input type="submit" value="查詢"> </form> <table> <tr> <th>編號</th> <th>姓名</th> <th>年齡</th> <th>操作</th> </tr> {{each datas as value index}} <tr> <td>{{value.id}}</td> <td>{{value.name}}</td> <td>{{value.age}}</td> <td><a href="/users/add">新增</a></td> <td><a href="/users/del/{{value.id}}">刪除</a></td> <td><a href="/users/toUpdate/{{value.id}}">修改</a></td> </tr> {{/each}} </table> </body> </html>
②add.html
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>新增頁面</title> </head> <body> <form action="/users/add" method="post"> 姓名:<input type="text" name="name"><br> 年齡:<input type="text" name="age"><br> <input type="submit" value="提交"> </form> </body> </html>
③update.html
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>修改頁面</title> </head> <body> <form action="/users/update" method="post"> <input type="hidden" value="{{datas[0].id}}" name="id"> 姓名:<input type="text" name="name" value="{{datas[0].name}}"><br> 年齡:<input type="text" name="age" value="{{datas[0].age}}"><br> <input type="submit" value="提交"> </form> </body> </html>
④user.js
var express = require('express'); var router = express.Router(); //引入資料庫包 var db = require("./db.js"); /* GET users listing. */ // router.get('/', function(req, res, next) { // res.send('respond with a resource'); // }); /** * 查詢列表頁 */ router.get('/', function (req, res, next) { db.query('select * from userinfo', function (err, rows) { if (err) { res.render('users', {title: 'Express', datas: []}); // this renders "views/users.html" } else { res.render('users', {title: 'Express', datas: rows}); } }) }); /** * 新增頁面跳轉 */ router.get('/add', function (req, res) { res.render('add'); }); router.post('/add', function (req, res) { var name = req.body.name; var age = req.body.age; db.query("insert into userinfo(name,age) values('" + name + "'," + age + ")", function (err, rows) { if (err) { res.end('新增失敗:' + err); } else { res.redirect('/users'); } }) }); /** * 刪 */ router.get('/del/:id', function (req, res) { var id = req.params.id; db.query("delete from userinfo where id=" + id, function (err, rows) { if (err) { res.end('刪除失敗:' + err) } else { res.redirect('/users') } }); }); /** * 修改 */ router.get('/toUpdate/:id', function (req, res) { var id = req.params.id; db.query("select * from userinfo where id=" + id, function (err, rows) { if (err) { res.end('修改頁面跳轉失敗:' + err); } else { res.render("update", {datas: rows}); //直接跳轉 } }); }); router.post('/update', function (req, res) { var id = req.body.id; var name = req.body.name; var age = req.body.age; db.query("update userinfo set name='" + name + "',age='" + age + "' where id=" + id, function (err, rows) { if (err) { res.end('修改失敗:' + err); } else { res.redirect('/users'); } }); }); /** * 查詢 */ router.post('/search', function (req, res) { var name = req.body.s_name; var age = req.body.s_age; var sql = "select * from userinfo"; if (name) { sql += " and name='" + name + "' "; } if (age) { sql += " and age=" + age + " "; } sql = sql.replace("and","where"); db.query(sql, function (err, rows) { if (err) { res.end("查詢失敗:", err) } else { res.render("users", {title: 'Express', datas: rows, s_name: name, s_age: age}); } }); }); module.exports = router;
效果展示:
1.剛開啟頁面的時候,由於資料庫沒有資料,因此頁面效果是醬紫滴:
預設埠號是3000,由於我的3000被占用,因此在bin/www中修改埠號;
2.完整的頁面效果是醬紫滴:
其中,新增、刪除以及修改也是可以正常使用的。
到此,簡單的使用nodejs+express+MySQL的crud小demo就完成了。每次多學一點知識的時候,總是少不了好同事的幫忙
下面關於Node.js的內容你可能也喜歡:
在 Ubuntu 14.04/15.04 上安裝設定 Node.js v4.0.0 http://www.linuxidc.com/Linux/2015-10/123951.htm
如何在CentOS 7安裝Node.js http://www.linuxidc.com/Linux/2015-02/113554.htm
Ubuntu 14.04下搭建Node.js開發環境 http://www.linuxidc.com/Linux/2014-12/110983.htm
Ubunru 12.04 下Node.js開發環境的安裝設定 http://www.linuxidc.com/Linux/2014-05/101418.htm
Node.Js入門[PDF+相關程式碼] http://www.linuxidc.com/Linux/2013-06/85462.htm
Node.js開發指南 高清PDF中文版 +原始碼 http://www.linuxidc.com/Linux/2014-09/106494.htm
Node.js入門開發指南中文版 http://www.linuxidc.com/Linux/2012-11/73363.htm
Ubuntu 編譯安裝Node.js http://www.linuxidc.com/Linux/2013-10/91321.htm
Ubuntu 16.04 64位元 搭建 Node.js NodeJS 環境 http://www.linuxidc.com/Linux/2016-09/135487.htm
相關文章