内容简介:基于 Sqlite3 的项目,直接是用 Sequelize 进行对象和表的映射。
SQLite 是一种嵌入式数据库,它的数据库就是一个文件。
Sequelize 是一个基于 promise 的 Node.js ORM , 目前支持 Postgres , MySQL , MariaDB , SQLite 以及 Microsoft SQL Server . 它具有强大的事务支持, 关联关系, 预读和延迟加载,读取复制等功能.
基于 Sqlite 3 的项目,直接是用 Sequelize 进行对象和表的映射。
环境配置
// 安装 npm i sequelize sqlite3 -S
项目结构
配置文件夹 config
// config/config.js
const path = require('path')
const sqlite3 = require('sqlite3').verbose()
module.exports = {
test: {
storage: path.join(__dirname, '../db/db_test.sqlite'), // 文件路径
host: 'localhost', // 地址
dialect: 'sqlite', // 目标数据库种类
dialectModule: sqlite3
logging: console.log,
}
}
注意:sqlite 可以忽略密码。(PS:使用密码可能会无法创建 sqlite 文件)
在 window 中需要手动引入 sqlite3 否则会找不到。
模型文件夹 models
该文件夹中 index.js 入口文件,链接数据库。
// models/index.js
const fs = require('fs')
const path = require('path')
const basename = path.basename(__filename) // 当前文件名
const Sequelize = require('sequelize')
const config = require('../config/config') // 配置文件
const sequelize = new Sequelize(undefined, undefined, undefined, config.test) // sqlite: 前三个参数传 undefined。
const db = {}
// 引入其他的Model文件。
fs.readdirSync(__dirname)
// 过滤:不是index.js, 含有.、以 .js 结尾的文件
.filter(file => (file.indexOf('.' !== 0) && (file !== basename) && (file.slice(-3) === '.js')))
.forEach(file => {
// 引入所有的Model文件
// 采用 import 引入
const model = sequelize.import(path.join(__dirname, file))
db[model.name] = model
})
// 关联配置
Object.keys(db).forEach(modelName => {
if (db[modelName].associate) {
db[modelName].associate(db)
}
})
db.sequelize = sequelize
db.Sequelize = Sequelize
module.exports = db
模型文件 User
// models/user.js
module.exports = (sequelize, DataTypes) => {
// 参数一:modelName: user
// 参数二:定义属性
// 参数三:其他配置 https://sequelize.org/master/class/lib/model.js~Model.html#static-method-init
const User = sequelize.define('user', {
name: {
type: DataTypes.STRING,
allowNull: false
},
age: {
type: DataTypes.INTEGER,
defaultValue: 0
},
gender: {
type: DataTypes.ENUM,
values: ['男', '女', '未知'],
defaultValue: '未知'
}
}, {
tableName: 'user'
})
User.associate = models => {
// 定义关联
}
return User
}
参考: 其他配置:options
知识点
分页
// controller/UserCtl.js
class UserCtl {
/**
* 获取所有用户
* @param {Object} ctx
*/
async index(ctx) {
// 分页 page, pageSize
// 使用 findAndCountAll 代替 findAll
const { page = 1, pageSize = 10 } = ctx.request.body
// 偏移量
let offset = (page - 1) * pageSize
try {
const {count, rows} = await db.user.findAndCountAll({
limit: parseInt(pageSize), // 页容量
offset: offset, // 偏移量
})
const data = {
code: 0,
msg: 'success',
totalCount: count,
data: rows,
}
ctx.ok(data)
} catch (error) {
const data = {
code: 1,
msg: '服务错误~',
err: error.name
}
ctx.badRequest(data)
}
}
}
findAndCountAll 和 findAll 区别。返回结果不同:前者返回 Promise <{count: number , rows: Model []}>,count 对象总数,rows本次查到的对象数组。后者直接返回对象数组。
有人遇到个错误:分页总数计算错误问题) (PS:暂时还没有遇到)
以上所述就是小编给大家介绍的《Koa使用Sqlite3和Sequelize》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- RecyclerView使用指南(一)—— 基本使用
- 如何使用Meteorjs使用URL参数
- 使用 defer 还是不使用 defer?
- 使用 Typescript 加强 Vuex 使用体验
- [译] 何时使用 Rust?何时使用 Go?
- UDP协议的正确使用场合(谨慎使用)
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
机器学习基础教程
(英)Simon Rogers,、Mark Girolami / 郭茂祖、王春宇 刘扬 刘晓燕、刘扬、刘晓燕 / 机械工业出版社 / 2014-1 / 45.00
本书是一本机器学习入门教程,包含了数学和统计学的核心技术,用于帮助理解一些常用的机器学习算法。书中展示的算法涵盖了机器学习的各个重要领域:分类、聚类和投影。本书对一小部分算法进行了详细描述和推导,而不是简单地将大量算法罗列出来。 本书通过大量的MATLAB/Octave脚本将算法和概念由抽象的等式转化为解决实际问题的工具,利用它们读者可以重新绘制书中的插图,并研究如何改变模型说明和参数取值。......一起来看看 《机器学习基础教程》 这本书的介绍吧!