Node的关系型数据库ORM库:bookshelf
NodeJs 关系数据库ORM库:Bookshelf.js
bookshelf.js是基于knex的一个关系型数据库的ORM库。简单易用,内置了Promise的支持。这里主要罗列一些使用的例子,例子就是最好的教程。下面就是用mysql作为实例数据库表明bookshelf如何使用。其他的几个关系型数据库使用上基本一致,只是配置等地方需要使用的名称各自不同。为了更加贴近实际全部的例子都会放在Express打造的RESTful服务里。
安装bookshelf和knex
首先需要安装库knex和bookshelf,其次还需要安装你的数据库对应的包:
npm install knex --save
npm install bookshelf --save
接下来,安装对应于你要使用的数据库的driver包。下面列出了三个比较典型的,只需要选择一个安装就可以。
npm install pg --save // PostgreSQL
npm install mysql --save // MySQL
npm install sqlite3 --save // SQLite
连接数据库
连接数据库就是非常的简单的,只需要传入一个JSON格式的配置:
var knex = require('knex'),
db; // 数据库连接
// 数据库连接配置
var config = {
client: 'mysql', // 其他可以是pg、sqlite3
connection: {
host: 'localhost',
user: 'root',
password: '123456',
database: 'petshop', // 数据库名称
charset: 'utf8'
}
};
// 保证数据库连接只初始化一次。
if (!db) {
db = knex(config);
}
接下来就该让bookshelf出马了:
var bookshelf = require('bookshelf')(db);
正式开始前,假设你现在有这么两个表Pet和User,分别存储宠物和宠物店的用户数据:
--pet
CREATE TABLE `pet` (
`petId` int(11) NOT NULL AUTO_INCREMENT,
`name` varchar(45) DEFAULT NULL,
`type` int(11) DEFAULT NULL,
`quantity` int(11) DEFAULT NULL,
`userId` int(11) NOT NULL, -- 外键,和哪个用户关联
PRIMARY KEY (`petId`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1;
--user
CREATE TABLE `user` (
`userId` int(11) NOT NULL AUTO_INCREMENT,
`username` varchar(45) DEFAULT NULL,
`password` varchar(45) DEFAULT NULL,
`email` varchar(105) DEFAULT NULL,
PRIMARY KEY (`userId`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1;
Express打造的RESTful服务代码:
var Promise = require('bluebird'),
express = require('express'),
bodyParser = require('body-parser'),
session = require('express-session');
var app = express();
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({extended: true}));
app.use(session({
secret: 'abcdefghijklmnopqrstuvwxyz1234567890',
resave: false,
saveUninitialized: true
// cookie: {secure: true}
}));
var models = require('./bookshelf');
var router = express.Router();
router.get('/', function(req, res) {
res.send('Hello bookshelf');
});
/**
* 添加
*/
router.route('/add').post(function(req, res) {
// ...
});
/**
* 更新
*/
router.route('/update').post(function(req, res) {
// ...
});
app.use('/bookshelf', router);
app.listen(4000, function(){
console.log('express is running on http://localhost:4000');
});
为了正常使用还需要安装某些包body-parser
,这个包用来解析post发送上来的数据。bluebird
和express-session
什么的可以选择不装,不影响。
Model
ORM,这model是必须不可以少的。如何让model来对应于数据库的table呢:
var Pet = bookshelf.Model.extend({
tableName: 'pet',
});
现在就可以使用Pet
来处理pet表的数据了。
上面是理论上的。回到本例中。首先在根目录下创建一个文件夹bookshelf,然后添加文件model.js。
添加数据
给表添加一条记录:
new Pet({
name: 'King',
type: 1, // 1: dog, 2: cat...
quantity: 10,
userId: 123456
}).save().then(function(model){
console.log(model);
}).catch(function(err) {
console.log(err);
});
放在RESTful API里:
router.route('/add').post(function(req, res) {
var pet = new models.Pet({
name: req.body.name,
type: req.body.type,
quantity: req.body.quantity,
userId: req.body.userId
});
pet.save().then(function(model){
res.json({message:'done', data: pet});
}).catch(function(err){
res.json({message: 'error', data: err});
});
});
在处理数据的时候可以使用bookshelf提供的很多“静态方法”。上面的extend
就是这些静态方法中的一个。创建新的model的时候就可以是用静态方法里的一个forge
,这样就不用new的方式了。
models.Pet.forge({
name: req.body.name,
type: req.body.type,
quantity: req.body.quantity,
userId: req.body.userId
}).save().then(function(pet){
res.json({message:'done', data: pet});
}).catch(function(err){
res.json({message: 'error', data: err});
});
查找数据
添加了数据就可以查找出来了。
查找全部
查找全部的数据:
router.route('/findall').get(function(req, res) {
models.Pet.forge().fetchAll().then(function(pets) {
res.json({message: 'done', data: pets});
}).catch(function(err) {
res.json({message: 'error', data: err});
});
});
在浏览器里输入地址:http://localhost:4000/bookshelf/findall可以查找出全部的pet数据。
查找某一个Pet
router.route('/find/:petId').get(function(req, res) {
models.Pet.forge({
petId: req.params.petId
}).fetch().then(function(pet) {
res.json({message: 'done', data: pet});
}).catch(function(err) {
res.json({message: 'error', data: err});
});
});
在浏览器里输入地址:http://localhost:4000/bookshelf/find/1可以查找出petId为1的数据。
我们在上一个例子中已经创建了一条记录,所以现在可以搜出来一条记录。
更多的更复杂的查找可以使用方法query
,查看这里了解更多。
更新数据
更新和创建一条新纪录,在写法上没什么太大的区别。只不过你需要在save
方法里设置需要更新的数据。但是有一个限制条件,就是需要在forge方法里给出id
,必须是这个词i
和d
。如果你的Primary key不是这个名称,那么就稍微复杂一点了。必须给出where
条件,比如:
router.route('/update/:petId').post(function(req, res) {
models.Pet.forge()
.where('petId', '=', req.params.petId)
.save({
name: req.body.name,
type: req.body.type,
quantity: req.body.quantity,
userId: req.body.userId
}, {patch: true}).then(function(pet) {
res.json({message: 'done', data: pet});
}).catch(function(err) {
res.json({message: 'error', data: err});
});
});
更多关于where
内容可以查看这里。
删除记录
最后可以删除记录。
router.route('/delete/:petId').get(function(req, res) {
models.Pet.forge()
.where('petId', '=', req.params.petId)
.destroy()
.then(function(pet) {
res.json({message: 'done', data: pet});
})
.catch(function(err) {
res.json({message: 'error', data: err});
});
});
最后
bookshelf这个库非常好用。不过这些还只是比较常用的一部分功能。还有很多的关系数据库的一对一、一对多以及多对多的关系的处理。
这些都可以在官方文档中查找到。
Node的关系型数据库ORM库:bookshelf的更多相关文章
- django model Foreign key usage 关系型数据库 ORM
django 的模型 from django.db import models""" A model pair to map car and its manufactur ...
- sqlyog管理关系型数据库mysql数据库之sqlyog的安装管理
.关系型数据库 有库有表,有关系 非关系型数据库 存储对象.集 下面的所有演示截图都是基不超过SQLyog 11进行的. 1. 2.点击上图中的应用程序,进行安装. 安装sqlyog , 账户dd0 ...
- Android 开源项目android-open-project工具库解析之(一) 依赖注入,图片缓存,网络相关,数据库orm工具包,Android公共库
一.依赖注入DI 通过依赖注入降低View.服务.资源简化初始化.事件绑定等反复繁琐工作 AndroidAnnotations(Code Diet) android高速开发框架 项目地址:https: ...
- MySQL(一) -- MySQL学习路线、数据库的基础、关系型数据库、关键字说明、SQL、MySQL数据库、MySQL服务器对象、SQL的基本操作、库操作、表操作、数据操作、中文数据问题、 校对集问题、web乱码问题
1 MySQL学习路线 基础阶段:MySQL数据库的基本操作(增删改查),以及一些高级操作(视图.触发器.函数.存储过程等). 优化阶段:如何提高数据库的效率,如索引,分表等. 部署阶段:如何搭建真实 ...
- Daject初探 - 一个开源关系型数据库对象关系映射(ORM)模型
Daject简介 Daject是用php写的一个关系型数据库抽象模型,通过该模型,可以在不写任何SQL或写很少的SQL就能执行大多数数据库查询操作.Daject具有面向对象,跨数据库的优点,通过数据库 ...
- 非关系型数据库(NoSql)
最近了解了一点非关系型数据库,刚刚接触,觉得这是一个很好的方向,对于大数据 方面的处理,非关系型数据库能起到至关重要的地位.这里我主要是整理了一些前辈的经验,仅供参考. 关系型数据库的特点 1.关系型 ...
- 数据库ORM框架GreenDao
常用的数据库: 1). Sql Server2). Access3). Oracle4). Sysbase5). MySql6). Informix7). FoxPro8). PostgreSQL9) ...
- Jetpack 架构组件 Room 数据库 ORM MD
Markdown版本笔记 我的GitHub首页 我的博客 我的微信 我的邮箱 MyAndroidBlogs baiqiantao baiqiantao bqt20094 baiqiantao@sina ...
- 《Andorid开源》greenDao 数据库orm框架
一 前言:以前没用框架写Andorid的Sqlite的时候就是用SQLiteDatabase ,SQLiteOpenHelper ,SQL语句等一些东西,特别在写SQL语句来进行 数据库操作的时 ...
随机推荐
- Django中反向生成models
我们在展示django ORM反向生成之前,我们先说一下怎么样正向生成代码. 正向生成,指的是先创建model.py文件,然后通过django内置的编译器,在数据库如mysql中创建出符合model. ...
- mvc中webapi添加后没法访问 解决办法
原因:原先项目中没有webapi,后来添加的. 然后就没法正常访问,百度了下发现是 App_Start/WebApiConfig.cs中路由配置多了个api 而且没有加{action}, 然后修改成: ...
- 关于PHP程序员技术职业生涯规划 2017年3月5日韩 天峰
看到很多PHP程序员职业规划的文章,都是直接上来就提Linux.PHP.MySQL.Nginx.Redis.Memcache.jQuery这些,然后就直接上手搭环境.做项目,中级就是学习各种PHP框架 ...
- C#做一个写txt文件流的测试,为什么配置低的机器写入的还快
测试机:笔记本i7 8G 固态硬盘 由于采取读码写入txt方式, 读码频率挺高,文件名为日期格式,当前采用每次读码打开文件写入的方式, 为什么没用sb,因为怕断电情况的数据丢失.所以采取每条存入的方式 ...
- PAT 1068 万绿丛中一点红(20)(测试点分析+思路分析)
1068 万绿丛中一点红(20 分) 对于计算机而言,颜色不过是像素点对应的一个 24 位的数值.现给定一幅分辨率为 M×N 的画,要求你找出万绿丛中的一点红,即有独一无二颜色的那个像素点,并且该点的 ...
- RabbitMQ 的基本介绍
RabbitMQ官网教程:http://www.rabbitmq.com/getstarted.html RabbitMQ 是一个由 Erlang 语言开发的 AMQP 的开源实现.AMQP :Adv ...
- iOS.PrototypeTools
1. iPhone/iPad 原型工具 http://giveabrief.com/ 2. proto.io https://proto.io/ 3. Origami http://facebook. ...
- NC 6系初始化EJB
6系开发时,调用远程接口去操作数据时,需先调用EJB. InvocationInfoProxy.getInstance().setUserDataSource(design); InvocationI ...
- UI设计初学者必备的工具以及学习路线(附思维导图)
今天千锋UI设计小编着重为大家介绍5个学习ui设计必须要会的工具和软件以及UI设计学习路线,希望能对大家所帮助. UI设计必要的工具和软件 1.PS 图像处理合成软件 ui设计核心软件,强大的图像处理 ...
- django数据库多对多修改对应关系
obj = models.Book.objects.get(id=1) #添加对应关系,给书添加作者# obj.m.add(3)# obj.m.add(2,4)# obj.m.add(*[1,2,3, ...