node.js数据库篇——MySQL

NoSQL大行其道的如今,MySQL这样的关系型数据库依然有着不可撼动的位置,对于中型,大型面向对象的项目,关系型数据库依然是首选,真正的项目,应当是将数据库的任务分离给专门的数据库工程师去完成。

本回介绍使用node.js连接mysql数据库,基于前面的express框架构建简单的购物车example。

node.js的MySQL驱动

数据库驱动是语言连接数据库的必备库,node.js连接mysql的基本驱动叫做“node-mysql”,另外node npm社区也提供了MySQL ORM的数据库驱动,就类似于上一回中的mongoose,基于模型映射的操作方式,叫做“node-sequelize”,性能相对于原生驱动肯定要差不少。

package.json

{
"name":"shopcart",
"version":"0.0.1",
"description":"a shopcart example powered by express and mysql",
"dependencies":{
"express":"latest",
"mysql":"latest",
"sequelize":"latest",
"jade":"latest"
}
}

测试连接

直接采用官方提供的连接示例:

var mysql      = require('mysql');

//创建并配置连接参数
var connection = mysql.createConnection({
host : 'localhost',
user : 'root',
password : '',
database : 'cslg'
}); //连接
connection.connect(); //测试查询语句,使用query输入SQL语句
connection.query('SELECT * from teacher_base_info limit 10', function (error, results, fields) {
if (error) throw error;
console.log(results);
}); //断开连接
connection.end();

读取成功

实践——购物车实现

需求分析

算了算,大概需要如下几个基本功能

  • /:展示所有商品以及添加商品的表单
  • /projects(POST):创建项目
  • /delete/:id(DELETE):删除项目
  • /project:/:id(GET):展示某个商品详情

为了示例简单,只做这几个功能罢了

创建数据库

使用phpmyadmin或者手动创建一个库,一张表

数据库叫:shopcart

表名:items

数据库配置文件

在开发项目时,应该将数据库账号密码的配置文件单独放在配置文件中,所以在项目目录下先新建dbconfig.json,使用json是因为js方便读取。

dbconfig.json

{
"host" : "localhost",
"user" : "root",
"password" : "",
"database" : "shopcart"
}

server.js

var mysql      = require('mysql');//引入mysql驱动
var dbconfig = require("./dbconfig.json");//引入数据库配置文件
var express = require("express")
var bodyParser = require('body-parser');
var app = express();
var connection = mysql.createConnection(dbconfig); //express框架基本配置
app.use(bodyParser.urlencoded({ extended: true })); //对post请求表单提交的数据编码,否则服务器端无法获得 app.set("view engine","jade");
app.set("views",__dirname+"/views"); connection.connect();
//主页
app.get("/",function(req,res){
connection.query('SELECT * from items', function(err, data, fields) {
if(err) throw err;
res.render("index",{items:data});
});
}) //删除一件商品
app.get("/delete/:id",function(req,res){
var id = req.params.id;
connection.query("delete from items where id=?",id,function(err,data,fields){
//affectedRows可查看删除行数
console.log(data.affectedRows);
res.redirect("/");
});
}); //插入一件商品
app.post("/projects",function(req,res){
console.log(req.body);
connection.query("insert into items SET ?",req.body,function(err, data, fields){
if(err) throw err;
//insertId可查看插入行的主键id编号
console.log(data.insertId);
res.redirect("/");
});
}); app.listen(3000);

分析套路

事实上在使用后我发现node-mysql模块使用十分简单:

  • 引入mysql模块,createConnection创建连接,传入配置文件json
  • 在请求代码前就连接上mysql,不要将connect放到get,post中,最后也不用关闭
  • 使用query操作数据库,第一个参数为数据库语句,可以使用“?”为占位符,第二个参数为替代占位符的对象,或者单一变量
  • 最后一个参数为回调函数,其中第二个参数是数据库返回的结果

从头到尾只使用一个query方法,传入数据库语句,回调函数获取数据即可,非常简单

前端文件

layout.jade

doctype html
html
head
title My shopping cart
body
h1 My shopping cart
#cart
block body

index.jade

extends layout
block body
h2 所有商品 if(items.length)
ul
each item in items
li
h3: a(href="/project/#{item.id}")=item.title
p=item.description
span: a(href="/delete/#{item.id}") 删除
else
p 没有任何商品 h2 创建新的商品 form(action="/projects",method="POST")
p
label 标题
input(type="text",name="title")
p
label 详情
textarea(name="description")
p
button 提交

最新文章

  1. MyBatis入门基础(一)
  2. tyvj1008 传球游戏
  3. Android_文件存储
  4. 如何更好地利用Pmd、Findbugs和CheckStyle分析结果
  5. File类的createNewFile()与createTempFile()的区别
  6. android使用Webview上传图片
  7. C2C,B2C,F2C三种电商运营模式的比较
  8. ruby学习总结03
  9. ie6的兼容问题及解决方案
  10. rpc和websocket的区别
  11. Altera Soc交叉编译环境搭建
  12. Delphi中使用Dos窗口输出调试信息
  13. PDO绑定含IN的SQL语句的参数注意事项
  14. Day12 CSS简单用法
  15. springboot 配置mybatis
  16. 2016年 CodePen 最热门的前端代码 Top 100
  17. new关键字对构造函数做了什么
  18. Git 目录
  19. 空指针、NULL指针、零指针
  20. Java-动态代理技术

热门文章

  1. [转载]markown语法
  2. sphinx转pdf显示中文
  3. Tidb go mac 上开发环境搭建
  4. day50-线程-定时器
  5. Android开发学习3
  6. java数据库执行迁移报错Error creating bean with name 'flywayInitializer' defined in class path resource
  7. 基于邻接表的长度为k的简单路径的求解
  8. python学习——tuple
  9. 【Python杂货铺】速学python基础
  10. 编译原理_P1002