node连接--MySQL
MySQL驱动器:node-mysql;
MySQL对象关系映射器:node-sequelize;
例子:
- package.json:
{
"name": "shopping-cart-example",
"version": "0.0.1",
"dependencies": {
"express": "2.5.2",
"jade": "0.19.0",
"mysql": "0.9.5"
}
} - config.json:
{
"host": "localhost",
"password": "123",
"database": "cart-example"
} - setup.js:
var mysql = require('mysql');
var config = require('./config'); //初始化客户端
delete config.database;
var db = mysql.createClient(config); //创建数据库
db.query('CREATE DATABASE IF NOT EXISTS `cart-example`');
db.query('USE `cart-example`'); //创建表
db.query('DROP TABLE IF EXISTS item');
db.query('CREATE TABLE item (' +
'id INT(11) AUTO_INCREMENT,' +
'title VARCHAR(255),' +
'description TEXT,' +
'created DATETIME,' +
'PRIMARY KEY(id))'
);
db.query('DROP TABLE IF EXISTS review');
db.query('CREATE TABLE review (' +
'id INT(11) AUTO_INCREMENT,' +
'item_id INT(11),' +
'text TEXT,' +
'stars INT(1),' +
'created DATETIME,' +
'PRIMARY KEY(id))'
); //关闭客户端
db.end(function() {
process.exit();
}); - server.js:
var express = require('express');
var mysql = require('mysql');
var config = require('./config'); app = express.createServer(); app.use(express.bodyParser());
app.set('view engine', 'jade');
app.set('views','views');
app.set('view options', {layout: false}); //连接数据集
var db = mysql.createClient(config); //首页路由
app.get('/', function(req, res, next) {
db.query('SELECT id, title, description FROM item', function(err, results) {
res.render('index', {items: results});
});
});
//创建商品的路由
app.post('/create', function(req, res, next) {
//使用?避免字符串拼接,从而避免SQL注入攻击,但需要使用替换数据的第二参数
db.query('INSERT INTO item SET title = ?, description = ?',
[req.body.title, req.body.description], function(err, info) {
if(err) return next(err);
//通过info.insertId来创建商品的id
console.log('-item created with id %s', info.insertId);
res.redirect('/');
});
});
//查看商品路由
app.get('/item/:id', function(req, res, next) {
function getItem (fn) {
db.query('SELECT id, title, description FROM item WHERE id= ? LIMIT 1',
[req.params.id], function (err, results) {
if(err) return next(err);
if(!results[0]) return res.send(404);
fn(results[0]);
});
}
function getReviews (item_id, fn) {
db.query('SELECT text, stars FROM review WHERE item_id= ?',
[item_id], function (err, results) {
if(err) return next(err);
fn(results);
});
}
getItem(function (item) {
getReviews(item.id, function (reviews) {
res.render('item', {item: item, reviews: reviews});
});
});
});
//评价商品的路由
app.post('/item/:id/review', function(req, res, next) {
db.query('INSERT INTO review SET item_id = ?, stars = ?, text = ?',
[req.params.id, req.body.stars, req.body.text], function(err, info) {
if (err) return next(err);
console.log('-review created with id %s', info.insertId);
res.redirect('/item/' + req.params.id);
});
}); app.listen(3000, function() {
console.log(' - listeing on http://*:3000');
}); - views/layout.jade:
doctype 5
html
head
title My shopping cart
body
h1 My shopping cart
#cart
block body - views/index.jade:
extends layout
block body
h2 All items
if(items.length)
ul
each item in items
li
h3: a(href='/item/#{item.id}')=item.title
=item.description
else
p No items to show
h2 Create new item form(action='/create', method='post')
p
label Title
input(type='text', name='title')
p
label Description
textarea(name='description')
p
button Submit - views/item.jade:
extends layout
block body
a(href='/') Go back
h2= item.title
p= item.description
h3 User reviews
if(reviews.length)
each review in reviews
.review
b #{review.stars} stars
p= review.text
hr
else
p No reviews to show. Write one! form(action='/item/#{item.id}/review', method='POST')
fieldset
legend Create review
p
label Stars
select(name='stars')
option 1
option 2
option 3
option 4
option 5
p
label Review
textarea(name='text')
p
button(type='submit') Send
sequelize:
上面例子的问题:建表的过程是手动的;表的定义不是项目一部分(单独的setup.js),应用程序无法进行校验;
sequelize通过定义schema和模型同时使用同步特性来创建数据库表(不需要单独建立);
- 连接sequelzie:
var Sequelize = require('sequelize');
var sequelize = new Sequelize('todo-example', 'root');
Sequelize构造器接受参数包括:
- database(String)
- username(String) //必要
- password(String) //可选
- other option(Object) //可选
- host(String)
- port(Number)
- 定义模型和同步:使用sequelize.define方法,第一参数为模型名,第二参数是包含了属性的对象;
var Project = sequelize.define('Project', {
title : Sequelize.STRING,
description: Sequelize.TEXT,
created: Sequelize.DATE
});对应的MySql类型:
- Sequelize.STRING //VARCHAR(255)
- Sequelize.BOOLEAN //TINYINT(1)
- Sequelize.TEXT //TEXT
- Sequelize.DATE //DATETIME
- Sequelize.INTEGER //INT
此外还可以传递选项对象: title: {type: Sequelize.STRING, default: 'title'}
- 例子://注意要先建好数据库 建立数据库
- server.js
var express = require('express');
var Sequelize = require('sequelize'); app = express.createServer(); //注意格式
app.use(express.static(__dirname + '/public'));
app.use(express.bodyParser()); app.set('view engine', 'jade');
app.set('views','views');
app.set('view option', {layout: false}); //首页路由
app.get('/', function (req, res, next) {
Project.findAll()
.success( function (projects) {
res.render('index', {projects: projects});
})
.error(next);
});
//删除项目路由
app.del('/project/:id', function (req, res, next) {
Project.find(Number(req.params.id)).success(function (proj) {
proj.destroy()
.success(function () {
res.rend(200);
})
.error(next);
}).error(next);
});
//创建项目路由
app.post('/projects', function (req, res, next) {
Project.build(req.body).save()
.success(function (obj) {
res.send(obj);
})
.error(next);
});
//展示指定项目路由
app.get('/project/:id/tasks', function (req, res, next) {
Project.find(Number(req.params.id))
.success(function (project) {
project.getTasks().on('success', function (tasks) {
res.render('tasks', {project: project, tasks: tasks});
})
})
.error(next); });
//为指定项目添加任务
app.post('/project/:id/tasks', function (req, res, next) {
res.body.ProjectId = req.params.id;
Task.build(req.body).save()
.success(function (obj) {
res.send(obj);
})
.error(next);
});
//删除任务路由
app.del('/task/:id', function (req, res, next) {
Task.find(Number(req.params.id)).success(function (task) {
task.destroy()
.success(function () {
res.send(200);
})
.error(err);
}).error(next);
}); app.listen(3000, function() {
console.log(' - listening on http://*3000');
}); //初始化,处于对结构清晰的考虑,在应用设置后做;
var sequelize = new Sequelize('todo-example', 'root','123'); //定义任务模型
var Project = sequelize.define('Project', {
title: Sequelize.STRING,
description: Sequelize.TEXT,
created: Sequelize.DATE
}) var Task = sequelize.define('Task', {
title: Sequelize.STRING
}); //设置联合
Task.belongsTo(Project);
Project.hasMany(Task); //同步
sequelize.sync(); - views/layout.jade
doctype 5
html
head
title TODO list app
script(src='/lib/jquery.min.js')
script(src='/main.js')
body
h1 TODO list app
#todo
block body - views/index.jade
extends layout
block body
h2 All items
if(items.length)
ul
each item in items
li
h3: a(href='/item/#{item.id}')=item.title
=item.description
else
p No items to show
h2 Create new item form(action='/create', method='post')
p
label Title
input(type='text', name='title')
p
label Description
textarea(name='description')
p
button Submit - views/tasks.jade
h2 Tasks for project #{project.title} #list
ul#tasks-list
each task in tasks
li
span= task.title
a.delete(href='/task/#{task.id}') X form#add(action='/project/#{project.id}/tasks', method='POST')
input(type= 'text', name= 'title')
button Add - public.main.js
$(function () {
$('form').submit( function (ev) {
ev.preventDefault();
var form = $(this);
$.ajax({
url: form.attr('action'),
type: 'POST',
data: form.serialize(),
success: function (obj) {
var el = $('<li>');
if ($('#projects-list').length) {
el.append($('<a>').attr('href', '/project/' + obj.id + '/tasks').text(obj.title + ' '))
.append($('<a>').attr('href', '/project/' + obj.id).attr('class', 'delete').text('x'));
}
$('ul').append(el);
}
});
form.find('input').val(''); //clear input
$('ul').delegate('a.delete', 'click', function (ev) {
ev.preventDefault();
var li = $(this).closest('li');
$.ajac({
url: $(this).attr('href'),
type: 'DELETE',
SUCCESS: function () {
li.remove();
}
})
})
}); });
node连接--MySQL的更多相关文章
- Node 连接Mysql并进行增删改查
NPM: NPM的全称是Node Package Manager,类似于ruby的gem,Python的PyPL.setuptools,PHP的pear,是Nodejs中的包管理器.Nodejs自身提 ...
- node连接mysql数据库
1. 创建项目,安装mysql 创建项目文件夹test, 在test文件夹下yarn add mysql --save安装mysql: 2. node使用mysql 在test文件夹下,创建test. ...
- node连接Mysql报错ER_NOT_SUPPORTED_AUTH_MODE
报错信息 本人系统安装的是mysql-installer-community-8.0.18.0.msi这个版本,然后我本地使用node-mysql去连接数据库. test.js文件 var mysql ...
- node 连接MySQL及其分装, 连接池连接
const mysql = require('mysql') const config = require('./../../config/config.default') var connectio ...
- node 连接 mysql 数据库三种方法------笔记
一.mysql库 文档:https://github.com/mysqljs/mysql mysql有三种创建连接方式 1.createConnection 使用时需要对连接的创建.断开进行管理 2. ...
- Node连接MySQL
http://blog.fens.me/nodejs-mysql-intro/ http://czpae86.iteye.com/blog/1636302 http://www.cnblogs.com ...
- Node.js Express连接mysql完整的登陆注册系统(windows)
windows学习环境: node 版本: v0.10.35 express版本:4.10.0 mysql版本:5.6.21-log 第一部分:安装node .Express(win8系统 需要&qu ...
- Node.js连接Mysql,并把连接集成进Express中间件中
引言 在node.js连接mysql的过程,我们通常有两种连接方法,普通连接和连接池. 这两种方法较为常见,当我们使用express框架时还会选择使用中间express-myconnection,可以 ...
- paip.最好的脚本语言node js 环境搭建连接mysql
paip.最好的脚本语言node js 环境搭建连接mysql #====下载node...走十一个exe..容易的.. 1 #0----Hello world .js 2 #---------模 ...
随机推荐
- chrome 调试基本信息学习
学习链接: remote-debugging-port相关: http://blog.chromium.org/2011/05/remote-debugging-with-chrome-develop ...
- HDU3344(小广搜+小暴力
Kakuro Extension Extension Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Ja ...
- 解决港版A1530 ios8 联通4G 电话打不进无法接通的问题,联通4G开关开启方法
GF的iPhone5s港版A1530联通4G老是出现无法接通的问题, 根本原因是没有4G开关.港行iPhone却只有3G开关.也就是说,当启动3G时,却搜到4G信号,但是关闭时却只能关闭3G和2G.让 ...
- ubuntu上完全卸载package
inux上完整的卸载apt方式安装软件的办法. 假设你的包叫做: your_pkg apt-get --purge remove your_pkg apt-get autoremove apt-get ...
- ssh连接慢的问题的解决?
<1>群中同学遇到的问题,我之前在uuwatch也遇到了同样的问题? 问个问题师兄们 突然之间 公司服务器连接很慢 连一个shell需要10几秒钟 服务器就在公司全是内网服务器, 我也不知 ...
- 【OpenStack】OpenStack系列10之Horizon详解
一.参考其他资料即可.可以采用haproxy+apache+horizon方式部署,haproxy/httpd支持ssl.
- 交换排序—冒泡排序(Bubble Sort)
基本思想: 在要排序的一组数中,对当前还未排好序的范围内的全部数,自上而下对相邻的两个数依次进行比较和调整,让较大的数往下沉,较小的往上冒. 即:每当两相邻的数比较后发现它们的排序与排序要求相反时,就 ...
- Linux set env export declare unset
http://www.it165.net/os/html/201405/8390.html env /etc/profile 环境变量 系统提供 可改 set /etc/bashrc及用户自定义的变量 ...
- windows下如何对mysql进行整裤备份
通常情况下备份一个数据库,直接单裤备份即可,更完善一点的会要求做到定时单裤备份.然而很多时候又由于裤实例是在太多,这样会导致备份非常耗时,因而有时候需要对整个数据库应用进行备份.那么在windows下 ...
- iOS 中contraints居中对齐的一点心得
今天遇到一个布局问题,先看图 如何让第二个控件在第一个和第三个的竖直上的中间呢?contraint不能直接实现这样的效果.我们可以再添加一个控件,如图 这样之后,再把第二个控件和这个新添加的控件设置为 ...