绝版Node--Sequlize搭建服务(Node全栈之路)
绝版Node--Sequlize搭建服务(Node全栈之路)
参考资料:https://itbilu.com/nodejs/npm/VkYIaRPz-.html
准备环境:Mysql,Node
前沿:
为大家介绍一下,什么是sequlize,ssequlize是基于node的一个ORM框架,如果你有Java 或者是C#开发经验,我们在操作数据库的时候会用到一些ORM映射数据库的表实体到我们程序中的实体类,这里我们称之为关系对象。
这里说几种ORM框架,NET中我们有EF(微软)、NHibernate(开源),Java中我们有Hibernate,同样Node的出现,它也有自己的ORM,那就是sequlize,它的出现,大大简化了繁杂的sql语句操作数据库,使得我们编程更加高效,这里ORM的出现,其优点可不是为了让你少些SQL的,它会提供他自己的一套处理O-R-M 之间的关系,这样使得我们处理一些复杂数据的时候,非常容易。
对于老鸟来说:ORM上手起来是非常容易的,首先我们从它的基本增删该查讲起,其次我们掌握基本增删该查后,会学习表之间的关系如何创建,(每一个ORM都有他自己的一套指定表关系的模式),本人这里熟悉EF,了解NHibernate,刚刚掌握Sequlize,指定表关系也无非就是,A表B表C表之间的关系,一对多,多对多,一对一。
对于每一个ORM来说,掌握了这些,就可以开发使用了。
正式开始||
首先我们要创建一个本地文件夹
用Dos定为到这个文件夹,执行npm init 将其创建成为一个Node包
然后在这个包里安装sequlize,具体操作如下截图
然后在你刚创建的文件夹里创建一个index.js文件,我们今天所有的代码,都将在index.js里写,并且index.js也是我们的一个主入口文件。
基本增删改查(index.js文件操作)
//引入框架 const Sequelize = require('sequelize');
//创建ORM实例
const sequelize = new Sequelize('api', 'root','',
{
'dialect': 'mysql', // 数据库使用mysql
}
); sequelize
.authenticate()
.then(()=>{
console.log('链接成功');
})
.catch((error)=>{
console.log('链接失败'+error);
})这里需要连接我们的MYSQL数据库
当我们连接好数据库后,需要创建模型,之后sequlize会自动将你创建的模型映射到数据库
下面我们就可以用User这个对象 来对数据库中的user表经行增删改查的操作了
我们真的完事大吉了吗?如果你这么认为,那就错了!.....我们需要把模型同步到数据库里
那么现在你得数据库就会自动创建好一张表
那么现在就可以真正经行增删该查的操作了
不过这里需要强调一点:
进入增删该查:
这里我需要彻头彻尾的粘贴一下代码,不然读者该骂了
//引入框架
const Sequelize = require('sequelize');
//创建ORM实例 api是我的数据库名字 root登录数据库名 ‘’表示登录我的数据库不需要密码
const sequelize = new Sequelize('api', 'root','',
{
'dialect': 'mysql', // 数据库使用mysql
}
); sequelize
.authenticate()
.then(()=>{
console.log('链接成功');
})
.catch((error)=>{
console.log('链接失败'+error);
}) //模型的创建
//1,用代码定义模型,然后同步到数据库中
//2,通过已有数据库生成ORM model //自己看的知识点:数据验证,要求,age不能为负数! //这里我创建了三个模型对象 ,会在数据中生成三张表
const User = sequelize.define('user',{
name:Sequelize.STRING,//定义表结构 name 为string类型
age:Sequelize.INTEGER,//定义表结构
}); const Message = sequelize.define('message',{
text:Sequelize.STRING,//定义表结构
}); const Image = sequelize.define('image',{
url:Sequelize.STRING,//定义表结构
});//同步所有的model和所有关系
sequelize.sync();下面在做修改,修改要加id,不加id会报错
下面我们在做查询操作
// 单条数据查询
SELECT `id`, `first_name` AS `firstName`, `lastName`, `createdAt`, `updatedAt` FROM `user` AS `user` WHERE `user`.`id` = 1 // 多条数据查询
SELECT `id`, `first_name` AS `firstName`, `lastName`, `createdAt`, `updatedAt` FROM `user` AS `user`在这里再补充点查询 ,(如果我们想查询部分字段怎么半)
// User.findOne().then(u=>{
// console.log('==========================');
// console.log(u.dataValues);
// console.log('=========================='); // });
// //第二查询
User.findAll({
where:{id:2},
attributes:['lastName']//查询部分字段,即不必查询出来你表中所有的字段 类似于 select xx,cc from table
})
.then((users)=>{
console.log('==========================');
console.log(JSON.stringify(users));
console.log('==========================');
});
// //第三查询
// User.findOne({where:{id:2}})
// .then((users)=>{
// console.log('==========================');
// console.log(JSON.stringify(users));
// console.log('==========================');
// }); // //第四查询
// User.findOne({where:{id:3}})
// .then((u)=>{
// console.log('==========================');
// // console.log(u);
// console.log('=========================='); // });最后我们说删除
好了,记住,删除叫destroy!!!
基本增删该查我们就到这里,下一篇文章讲一下,如何实现多表之间的对应关系,一对一hasOne 一对多 belong to hasManay .
..如果有问题的朋,欢迎加我微信:jkxx123321
绝版Node--Sequlize搭建服务(Node全栈之路)的更多相关文章
- 绝版Node--Sequlize搭建服务(Node全栈之路 二)
在Node全栈之路(一),也就是上篇文章中,我们讲到了sequlize的基本增删该查,这篇文章,我们在上篇文章的基础上继续探讨,讲一下关于sequlize创建的表之间的对应关系 参考资料:https: ...
- C蛮的全栈之路-node篇(二) 实战一:自动发博客
目录 C蛮的全栈之路-序章 技术栈选择与全栈工程师C蛮的全栈之路-node篇(一) 环境布置C蛮的全栈之路-node篇(二) 实战一:自动发博客 ---------------- 我是分割线 ---- ...
- C蛮的全栈之路-node篇(一) 环境布置
目录 C蛮的全栈之路-序章 技术栈选择与全栈工程师C蛮的全栈之路-node篇(一) 环境布置C蛮的全栈之路-node篇(二) 实战一:自动发博客 ---------------- 我是分割线 ---- ...
- C蛮的全栈之路-序章 技术栈选择与全栈工程师
目录 C蛮的全栈之路-序章 技术栈选择与全栈工程师C蛮的全栈之路-node篇(一) 环境布置C蛮的全栈之路-node篇(二) 实战一:自动发博客 博主背景 985院校毕业,至今十年C++开发工作经验, ...
- python 全栈之路
目录 Python 全栈之路 一. Python 1. Python基础知识部分 2. Python -函数 3. Python - 模块 4. Python - 面对对象 5. Python - 文 ...
- Python全栈之路目录结构
基础 1.Python全栈之路-----基础篇 2.Python全栈之路---运算符与基本的数据结构 3.Python全栈之路3--set集合--三元运算--深浅拷贝--初识函数 4.Python全栈 ...
- Python全栈之路----目录
Module1 Python基本语法 Python全栈之路----编程基本情况介绍 Python全栈之路----常用数据类型--集合 Module2 数据类型.字符编码.文件操作 Python全栈之路 ...
- Python全栈之路----常用模块----hashlib加密模块
加密算法介绍 HASH Python全栈之路----hash函数 Hash,一般翻译做“散列”,也有直接音译为”哈希”的,就是把任意长度的输入(又叫做预映射,pre-image),通过散列 ...
- Node.js 中开源库探秘 object-assign | 全栈之路
这篇内容呢,讲的是另一个技术栈 Node.js 系列,虽然和咱们这里的主题不是特别吻合,不过嘛,汲取多样性的养分是快速成长的好方法,也是现在流行的全栈工程师的必经之路. 由于这篇内容涉及的是 Node ...
随机推荐
- Grape教程-params
参数 请求参数可以通过params获取,params是一个hash对象,包括GET.POST.PUT参数,以及路径字符串中的任何命名参数: get :public_timeline do Status ...
- 搭建Golang开发环境
Go语言是谷歌 2009 年首次推出并在 2012 年正式发布的一种全新的编程语言,可以在不损失应用程序性能的情况下降低代码的复杂性.谷歌首席软件工程师罗布派克(Rob Pike)说:我们之所以开发 ...
- CSS动画原理及硬件加速
一.图层 图层即层叠上下文,具体概念和应用大家可以看我之前转自张鑫旭大神博客的<CSS层叠上下文和层叠顺序>,这里我们简单复习一下产生层叠上下文的原因. 1.根层叠上下文 指的是页面根元素 ...
- Java类加载顺序
很长时间没看这方面的内容了,写篇文章让自己牢记一下,顺便分享一下. 首先,写代码以便检验结果.测试代码: public class Test { public static void main(Str ...
- 全网最详细的Windows系统里Oracle 11g R2 Database(64bit)安装后的初步使用(图文详解)
不多说,直接上干货! 前期博客 全网最详细的Windows系统里Oracle 11g R2 Database(64bit)的下载与安装(图文详解) 命令行方式测试安装是否成功 1) 打开服务(cm ...
- 解决org.apache.shiro.session.UnknownSessionException: There is no session with id的问题
一.背景 最近在整合了Spring+Shiro+Redis实现tomcat集群session共享的问题之后,发布以后运行以后发现老是会出现:org.apache.shiro.session.Unkno ...
- scala-03-list操作
列表 Scala 列表类似于数组,它们所有元素的类型都相同,但是它们也有所不同:列表是不可变的,值一旦被定义了就不能改变,其次列表 具有递归的结构(也就是链接表结构)而数组不是.. 1, 创建 lis ...
- Andrew Ng机器学习课程笔记(一)之线性回归
Andrew Ng机器学习课程笔记(一)之线性回归 版权声明:本文为博主原创文章,转载请指明转载地址 http://www.cnblogs.com/fydeblog/p/7364598.html 前言 ...
- logback打印mybatis sql日志
近期在项目中调试sql,发现现有的配置 使用logback 无法打印出sql语句,原配置如下(修改为debug也不好使): <!--jdbc --><logger name=&quo ...
- Python多版本管理器-pyenv 介绍及部署记录
一. pyenv简单介绍 在日常运维中, 经常遇到这样的情况: 系统自带的Python是2.x,而业务部署需要Python 3.x 环境, 此时需要在系统中安装多个Python版本,但又不能影响系统自 ...