NodeJS Express使用ORM模型访问关系型数据库流程详解

 更新时间:2023年01月10日 16:23:57   作者:秃头小宋s  
这篇文章主要介绍了NodeJS Express使用ORM模型访问关系型数据库流程,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习吧

一、ORM模型

设计思想,主要目的是简化计算机程序访问数据库

1、ORM:对象关系模型(对象关系映射) Object Releastion Model,将程序中的对象和数据库中关系(表格)进行映射。可以使开发者在程序中方便的对数据库进行操作(用户在程序操作对对象实际就是操作数据库的表格)

2、ORM的映射关系:

(1)程序中的模型(即为类) <——>表名

(2)模型的类型(类中定义的属性)<——> 表的列

(3)由模型创建的对象(类的实例) <——> 表中的行

二、在Node中ORM的实现

1、Sequelize模块:支持ORM映射的模块,可以访问关系型数据库,可以提高node程序访问数据库的开发效率。

2、Sequelize模块的使用:

(1)安装MySQL模块:npm install mysql2

(2)安装Sequelize模块:npm install sequelize

3、Sequelize模块的使用

(1)创建数据库的配置文件

导入

创建数据库的配置对象

//1.导入Sequelize模块
const Sequelize = require('sequelize');
//2.使用Sequelize模块配置和数据库的连接信息
const mysql_Sequelize = new Sequelize('sales','root','syy2589',{
    host:'localhost', //数据库服务器的IP地址或域名
    port:'3306', //数据库使用的端口号,MySQL数据库默认端口号3306
    dialect: 'mysql', //数据库的类型
    pool:{  //数据库连接池:可以放若干个数据库的连接对象,提高数据库访问效率
        max:20, //数据库连接池中连接对象的最大个数
        min:3, //数据库连接池中连接对象的最少个数
        idle:20000 //等待延迟的时间,单位:毫秒
    },
    define:{
        'charset':'utf8' //处理MySQL中中文字符的问题
    }
})
// 3.导出数据库的连接对象
module.exports = mysql_Sequelize;

注:new Sequelize(数据库名,用户名,密码,(配置信息))

 测试数据库是否连接成功

const mysqltest = require('./mysqlconfig.js');
mysqltest.authenticate() //用来测试数据库是否连接成功
    .then(()=>{
        console.log('数据库连接成功~')
    })
    .catch((err)=>{
        console.error(err);
    })

(2)创建模型:实现模型和数据表的映射

模型名 = sequelize.define('数据表名','模型的属性',{其他配置})

模型名 <——> 数据表名

模型的属性<——> 数据表列

const  Sequelize = require(sequelize);
//1.导入数据库的配置对象
const mysql_Sequelize = require('../config/mysqlconfig.js');
// 2.创建模型与数据库中的表实现映射
const Employee = mysql_Sequelize.define('employee',{
    'e_id':{
        type:Sequelize.STRING,
        // type:Sequelize.INTEGER, 表示id的数据类型为int型
        autoIncrement:false, //表示id的值在表中是否自增
        allowNull:false, //表示id对象的值不能为空
        fields:'e_id',//实现模型的属性名和表的列名之间的映射关系(对应关系)
    },
    'e_name':{
        type:Sequelize.STRING,
        autoIncrement:false,
        allowNull:false,
        fields: 'e_name',
    },
    'sex':{
        type:Sequelize.STRING,
        autoIncrement:false,
        allowNull:false,
        fields: 'sex',
    },
    'apartment':{
        type:Sequelize.STRING,
        autoIncrement:false,
        allowNull:true,
        fields: 'apartment',
    },
    'phone':{
        type:Sequelize.STRING,
        autoIncrement:false,
        allowNull:true,
        fields: 'phone',
    },
    'address':{
        type:Sequelize.STRING,
        autoIncrement:false,
        allowNull:true,
        fields: 'address',
    },
},{
    freezeTableName:true, //不使用Sequelize给模型自定义的表名(自定义表名的命名规则:模型名后加s)
    timestamps:false //若为true,在获取数据时会自动添加两列数据(createTime、updateTime)
});
// 导出模型
module.exports = Employee;

(3)创建接口文件:使用模型创建数据表

插入记录

模型名.create({ }).then((result)=>{}):then表示插入操作完成后的处理,result参数中保存有数据库返回的信息

// http://localhost:9000/employee/addemp
Emprouter.post('/addemp',(req,res)=>{
    console.log(req.body);
    Employee.create({
        id:req.body.id,
        name:req.body.name,
        sex:req.body.sex,
        apartment:req.body.apartment,
        phone:req.body.phone,
        address:req.body.address
    }).then((result)=>{
        if(result){
            res.json({
                code:1002
            })
        }
    })
})

(4)前端页面:使用jQuery向服务器端发起ajax请求

表单序列化:表单名.serizlize(),作用是将表单中所有控件的值序列化成字符串

删除记录

模型名:destroy({

where:{

列名:值

}

}).then((result)=>{

删除成功后的回调

}

更新记录

模型名.update({修改的列},{where条件}.then((result)={

更新成功后的回调

}).catch((e)=>{

出现异常的回调

})

查询记录

模型名.findAll().then((result)=>{ //result:是一个数组,存放的是从数据库中查询的所有记录

查询成功后的回调

}).catch((e)=>{

执行查询出现异常的回调

}

Emprouter.get('/findemp',(req,res)=>{
    if(req.url != './favicon.ico'){
        Employee.findAll().then((result)=>{
            res.send(JSON.stringify(result));
        })
    }
})

模糊查询:

在执行带条件查询时,需要导入Sequelize模块的Op子模块,在Op子模块中存放的是所有条件查询的关键字。

const Op = require('sequelize').Op;
Emprouter.post('/findlike',(req,res)=>{
    // 获取前端发送的部门
    let apartment = req.body.apartment;
    // 进行模糊查询
    Employee.findAll({
        where:{
            apartment:{
                [Op.like]:apartment+'%'
            }
        }
    }).then((result)=>{
        res.json(result);
    }).catch((e)=>{
        console.log(e);
        res.json('查询失败~')
    })
})

到此这篇关于NodeJS Express使用ORM模型访问关系型数据库流程详解的文章就介绍到这了,更多相关NodeJS Express访问关系型数据库内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 详解Node使用Puppeteer完成一次复杂的爬虫

    详解Node使用Puppeteer完成一次复杂的爬虫

    这篇文章主要介绍了详解Node使用Puppeteer完成一次复杂的爬虫,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-04-04
  • 在windows上用nodejs搭建静态文件服务器的简单方法

    在windows上用nodejs搭建静态文件服务器的简单方法

    这篇文章主要介绍了在windows上用nodejs搭建静态文件服务器的简单方法,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2016-08-08
  • Node.js 连接 MySql 统计组件属性的使用情况解析

    Node.js 连接 MySql 统计组件属性的使用情况解析

    这篇文章主要为大家介绍了Node.js 连接 MySql 统计组件属性的使用情况解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-10-10
  • 利用Node.js制作爬取大众点评的爬虫

    利用Node.js制作爬取大众点评的爬虫

    相信每位用过大众点评的人都知道,大众点评上有很多美食餐馆的信息,所以这篇文章给大家分享利用Node.js实现爬取大众点评的爬虫,正好可以拿来练练手Node.js。感兴趣的可以参考借鉴。
    2016-09-09
  • Node.js中你不可不精的Stream(流)

    Node.js中你不可不精的Stream(流)

    这篇文章主要给大家介绍了关于Node.js中你不可不精的Stream(流)的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2018-06-06
  • Node.js使用Angular简单示例

    Node.js使用Angular简单示例

    这篇文章主要介绍了Node.js使用Angular简单示例,如何在Node.js项目中引入AngularJS,这次提供一个非常简单的示例,演示AngularJS里的指令、数据绑定、服务等内容。感兴趣的小伙伴们可以参考一下
    2018-05-05
  • npm install报错unable to resolve dependency tree的解决办法

    npm install报错unable to resolve dependency tree的解决办法

    在开发过程中经常会使用npm安装依赖包来加速开发,但是在执行npm install命令时,有时会遇到各种错误,下面这篇文章主要给大家介绍了关于npm install报错unable to resolve dependency tree的解决办法,需要的朋友可以参考下
    2023-05-05
  • Nodejs 搭建简单的Web服务器详解及实例

    Nodejs 搭建简单的Web服务器详解及实例

    这篇文章主要介绍了Nodejs 搭建简单的Web服务器详解及实例的相关资料,并附实例代码和实现效果图,需要的朋友可以参考下
    2016-11-11
  • ndm:NPM的桌面GUI应用程序

    ndm:NPM的桌面GUI应用程序

    今天小编就为大家分享一篇关于ndm:NPM的桌面GUI应用程序,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2018-10-10
  • nodejs使用http模块发送get与post请求的方法示例

    nodejs使用http模块发送get与post请求的方法示例

    这篇文章主要介绍了nodejs使用http模块发送get与post请求的方法,结合实例形式分析了nodejs基于http模块实现发送get与post请求具体操作技巧,需要的朋友可以参考下
    2018-01-01

最新评论