中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

nodejs使用Sequelize框架實現操作數據庫

發布時間:2020-10-26 17:10:06 來源:億速云 閱讀:300 作者:Leah 欄目:開發技術

今天就跟大家聊聊有關nodejs使用Sequelize框架實現操作數據庫,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內容,希望大家根據這篇文章可以有所收獲。

sequelize.define

使用該方法可以定義model,例子如下:

const Sequelize = require('sequelize');

var sequelize = new Sequelize(config.database, config.username, config.password, {
 host: config.host,
 dialect: 'mysql',
 pool: {
  max: 5,
  min: 0,
  idle: 30000
 }
});

var Website = sequelize.define('website', {
 id: {
  type: Sequelize.BIGINT,
  primaryKey: true,
  autoIncrement: true
 },
 url: Sequelize.STRING(255),
 title: Sequelize.STRING(255),
 status: Sequelize.INTEGER,
 delete_mark: Sequelize.BOOLEAN
}, {
 timestamps: false
});

該方法傳入的第一個參數是數據表的單數形式,怎么理解呢?例如這里傳入的是website其實是模型名,數據表默認是websites這樣的復數形式,這種約定我在Laravel中也碰見過,

也就是常說的,約定大于定義,也就是說,如果我們都按照約定的規范去開發,那么效率其實比重新定義,要高很多。

那么,定義好了模型,該怎么進行使用呢?

(async () => {
 let demo = await Website.create({
  url:'http://www.xxxx.com/',
  title:'demo'
 });
 console.log(demo);
})();

繼承Model

const {Sequelize, DataTypes, Model} = require('sequelize');
const config = require('../config');

const sequelize = new Sequelize(config.database, config.username, config.password, {
 host: config.host,
 dialect: 'mysql',
 pool: {
  max: 5,
  min: 0,
  idle: 30000
 }
});

/**
 * @author chaojilaji
 * 數據表websites的關系對象映射
 */
class WebSite extends Model {

}

WebSite.init({
 id: {
  type: Sequelize.BIGINT,
  primaryKey: true,
  autoIncrement: true
 },
 url: Sequelize.STRING(255),
 title: Sequelize.STRING(255),
 status: Sequelize.INTEGER,
 delete_mark: Sequelize.BOOLEAN
}, {
 sequelize,
 modelName: 'Website',
 timestamps:false
});

(async () => {
 await sequelize.sync();
 let x = await WebSite.create({
  url: 'http://www.xxxxxxxx.com/',
  title: 'demo2'
 });
 console.log(x);
})();

module.exports = WebSite;

我比較推薦使用繼承Model這種方式,通過創建一個class,這樣可以使用model.exports=模塊名的方式,將該模型封裝起來。供別的地方使用,只需要require進去即可。

具體如何對數據表進行操作,就比較簡單了,只需要參考API即可。 sequelize文檔地址

看完上述內容,你們對nodejs使用Sequelize框架實現操作數據庫有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注億速云行業資訊頻道,感謝大家的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

武城县| 睢宁县| 澄江县| 安乡县| 龙泉市| 多伦县| 屏南县| 黄石市| 疏附县| 南城县| 永春县| 柯坪县| 原阳县| 西华县| 安福县| 延庆县| 东源县| 赤城县| 信宜市| 霍州市| 通许县| 朝阳市| 武陟县| 乃东县| 永泰县| 保康县| 砚山县| 比如县| 兴海县| 区。| 介休市| 大关县| 广南县| 陇川县| 恩施市| 临高县| 静海县| 突泉县| 南雄市| 璧山县| 寻乌县|