亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

NodeJS?Express使用ORM模型訪問關(guān)系型數(shù)據(jù)庫流程詳解

 更新時間:2023年01月10日 16:23:57   作者:禿頭小宋s  
這篇文章主要介紹了NodeJS?Express使用ORM模型訪問關(guān)系型數(shù)據(jù)庫流程,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧

一、ORM模型

設(shè)計思想,主要目的是簡化計算機程序訪問數(shù)據(jù)庫

1、ORM:對象關(guān)系模型(對象關(guān)系映射) Object Releastion Model,將程序中的對象和數(shù)據(jù)庫中關(guān)系(表格)進行映射??梢允归_發(fā)者在程序中方便的對數(shù)據(jù)庫進行操作(用戶在程序操作對對象實際就是操作數(shù)據(jù)庫的表格)

2、ORM的映射關(guān)系:

(1)程序中的模型(即為類) <——>表名

(2)模型的類型(類中定義的屬性)<——> 表的列

(3)由模型創(chuàng)建的對象(類的實例) <——> 表中的行

二、在Node中ORM的實現(xiàn)

1、Sequelize模塊:支持ORM映射的模塊,可以訪問關(guān)系型數(shù)據(jù)庫,可以提高node程序訪問數(shù)據(jù)庫的開發(fā)效率。

2、Sequelize模塊的使用:

(1)安裝MySQL模塊:npm install mysql2

(2)安裝Sequelize模塊:npm install sequelize

3、Sequelize模塊的使用

(1)創(chuàng)建數(shù)據(jù)庫的配置文件

導(dǎo)入

創(chuàng)建數(shù)據(jù)庫的配置對象

//1.導(dǎo)入Sequelize模塊
const Sequelize = require('sequelize');
//2.使用Sequelize模塊配置和數(shù)據(jù)庫的連接信息
const mysql_Sequelize = new Sequelize('sales','root','syy2589',{
    host:'localhost', //數(shù)據(jù)庫服務(wù)器的IP地址或域名
    port:'3306', //數(shù)據(jù)庫使用的端口號,MySQL數(shù)據(jù)庫默認(rèn)端口號3306
    dialect: 'mysql', //數(shù)據(jù)庫的類型
    pool:{  //數(shù)據(jù)庫連接池:可以放若干個數(shù)據(jù)庫的連接對象,提高數(shù)據(jù)庫訪問效率
        max:20, //數(shù)據(jù)庫連接池中連接對象的最大個數(shù)
        min:3, //數(shù)據(jù)庫連接池中連接對象的最少個數(shù)
        idle:20000 //等待延遲的時間,單位:毫秒
    },
    define:{
        'charset':'utf8' //處理MySQL中中文字符的問題
    }
})
// 3.導(dǎo)出數(shù)據(jù)庫的連接對象
module.exports = mysql_Sequelize;

注:new Sequelize(數(shù)據(jù)庫名,用戶名,密碼,(配置信息))

 測試數(shù)據(jù)庫是否連接成功

const mysqltest = require('./mysqlconfig.js');
mysqltest.authenticate() //用來測試數(shù)據(jù)庫是否連接成功
    .then(()=>{
        console.log('數(shù)據(jù)庫連接成功~')
    })
    .catch((err)=>{
        console.error(err);
    })

(2)創(chuàng)建模型:實現(xiàn)模型和數(shù)據(jù)表的映射

模型名 = sequelize.define('數(shù)據(jù)表名','模型的屬性',{其他配置})

模型名 <——> 數(shù)據(jù)表名

模型的屬性<——> 數(shù)據(jù)表列

const  Sequelize = require(sequelize);
//1.導(dǎo)入數(shù)據(jù)庫的配置對象
const mysql_Sequelize = require('../config/mysqlconfig.js');
// 2.創(chuàng)建模型與數(shù)據(jù)庫中的表實現(xiàn)映射
const Employee = mysql_Sequelize.define('employee',{
    'e_id':{
        type:Sequelize.STRING,
        // type:Sequelize.INTEGER, 表示id的數(shù)據(jù)類型為int型
        autoIncrement:false, //表示id的值在表中是否自增
        allowNull:false, //表示id對象的值不能為空
        fields:'e_id',//實現(xiàn)模型的屬性名和表的列名之間的映射關(guān)系(對應(yīng)關(guān)系)
    },
    '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給模型自定義的表名(自定義表名的命名規(guī)則:模型名后加s)
    timestamps:false //若為true,在獲取數(shù)據(jù)時會自動添加兩列數(shù)據(jù)(createTime、updateTime)
});
// 導(dǎo)出模型
module.exports = Employee;

(3)創(chuàng)建接口文件:使用模型創(chuàng)建數(shù)據(jù)表

插入記錄

模型名.create({ }).then((result)=>{}):then表示插入操作完成后的處理,result參數(shù)中保存有數(shù)據(jù)庫返回的信息

// 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向服務(wù)器端發(fā)起ajax請求

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

刪除記錄

模型名:destroy({

where:{

列名:值

}

}).then((result)=>{

刪除成功后的回調(diào)

}

更新記錄

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

更新成功后的回調(diào)

}).catch((e)=>{

出現(xiàn)異常的回調(diào)

})

查詢記錄

模型名.findAll().then((result)=>{ //result:是一個數(shù)組,存放的是從數(shù)據(jù)庫中查詢的所有記錄

查詢成功后的回調(diào)

}).catch((e)=>{

執(zhí)行查詢出現(xiàn)異常的回調(diào)

}

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

模糊查詢:

在執(zhí)行帶條件查詢時,需要導(dǎo)入Sequelize模塊的Op子模塊,在Op子模塊中存放的是所有條件查詢的關(guān)鍵字。

const Op = require('sequelize').Op;
Emprouter.post('/findlike',(req,res)=>{
    // 獲取前端發(fā)送的部門
    let apartment = req.body.apartment;
    // 進行模糊查詢
    Employee.findAll({
        where:{
            apartment:{
                [Op.like]:apartment+'%'
            }
        }
    }).then((result)=>{
        res.json(result);
    }).catch((e)=>{
        console.log(e);
        res.json('查詢失敗~')
    })
})

到此這篇關(guān)于NodeJS Express使用ORM模型訪問關(guān)系型數(shù)據(jù)庫流程詳解的文章就介紹到這了,更多相關(guān)NodeJS Express訪問關(guān)系型數(shù)據(jù)庫內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 詳解Node使用Puppeteer完成一次復(fù)雜的爬蟲

    詳解Node使用Puppeteer完成一次復(fù)雜的爬蟲

    這篇文章主要介紹了詳解Node使用Puppeteer完成一次復(fù)雜的爬蟲,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-04-04
  • 在windows上用nodejs搭建靜態(tài)文件服務(wù)器的簡單方法

    在windows上用nodejs搭建靜態(tài)文件服務(wù)器的簡單方法

    這篇文章主要介紹了在windows上用nodejs搭建靜態(tài)文件服務(wù)器的簡單方法,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2016-08-08
  • Node.js?連接?MySql?統(tǒng)計組件屬性的使用情況解析

    Node.js?連接?MySql?統(tǒng)計組件屬性的使用情況解析

    這篇文章主要為大家介紹了Node.js?連接?MySql?統(tǒng)計組件屬性的使用情況解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-10-10
  • 利用Node.js制作爬取大眾點評的爬蟲

    利用Node.js制作爬取大眾點評的爬蟲

    相信每位用過大眾點評的人都知道,大眾點評上有很多美食餐館的信息,所以這篇文章給大家分享利用Node.js實現(xiàn)爬取大眾點評的爬蟲,正好可以拿來練練手Node.js。感興趣的可以參考借鑒。
    2016-09-09
  • Node.js中你不可不精的Stream(流)

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

    這篇文章主要給大家介紹了關(guān)于Node.js中你不可不精的Stream(流)的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2018-06-06
  • Node.js使用Angular簡單示例

    Node.js使用Angular簡單示例

    這篇文章主要介紹了Node.js使用Angular簡單示例,如何在Node.js項目中引入AngularJS,這次提供一個非常簡單的示例,演示AngularJS里的指令、數(shù)據(jù)綁定、服務(wù)等內(nèi)容。感興趣的小伙伴們可以參考一下
    2018-05-05
  • npm?install報錯unable?to?resolve?dependency?tree的解決辦法

    npm?install報錯unable?to?resolve?dependency?tree的解決辦法

    在開發(fā)過程中經(jīng)常會使用npm安裝依賴包來加速開發(fā),但是在執(zhí)行npm install命令時,有時會遇到各種錯誤,下面這篇文章主要給大家介紹了關(guān)于npm?install報錯unable?to?resolve?dependency?tree的解決辦法,需要的朋友可以參考下
    2023-05-05
  • Nodejs 搭建簡單的Web服務(wù)器詳解及實例

    Nodejs 搭建簡單的Web服務(wù)器詳解及實例

    這篇文章主要介紹了Nodejs 搭建簡單的Web服務(wù)器詳解及實例的相關(guān)資料,并附實例代碼和實現(xiàn)效果圖,需要的朋友可以參考下
    2016-11-11
  • ndm:NPM的桌面GUI應(yīng)用程序

    ndm:NPM的桌面GUI應(yīng)用程序

    今天小編就為大家分享一篇關(guān)于ndm:NPM的桌面GUI應(yīng)用程序,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2018-10-10
  • nodejs使用http模塊發(fā)送get與post請求的方法示例

    nodejs使用http模塊發(fā)送get與post請求的方法示例

    這篇文章主要介紹了nodejs使用http模塊發(fā)送get與post請求的方法,結(jié)合實例形式分析了nodejs基于http模塊實現(xiàn)發(fā)送get與post請求具體操作技巧,需要的朋友可以參考下
    2018-01-01

最新評論