Sequelize 連接數(shù)據(jù)庫(kù)及創(chuàng)建模型

Sequelize 是 Node.js 的基于 Promise 的 ORM。 它可與 PostgreSQL婚温,MySQL召噩,SQLite 和 MSSQL 方言配合使用,并具有可靠的事務(wù)支持眼溶,關(guān)系,讀取復(fù)制等功能晓勇。(對(duì)象關(guān)系映射(ORM)是一種從面向?qū)ο蟮恼Z(yǔ)言訪問關(guān)系數(shù)據(jù)庫(kù)的技術(shù)堂飞。)
下面以MySQL為例。

首先安裝sequelize.js:

npm i sequelize

創(chuàng)建連接

這里把數(shù)據(jù)庫(kù)的基本信息做了一個(gè)封裝
基本信息配置文件 dbinfo.js

const config = {
    database: "db", // 數(shù)據(jù)庫(kù)名稱
    username: "root", // 用戶名
    password: "123456", // 密碼
    host: "localhost", // 主機(jī)地址
    port: "3306", // 端口號(hào)
    dialect: "mysql", //數(shù)據(jù)庫(kù)類型绑咱,支持: 'mysql', 'sqlite', 'postgres', 'mssql'
    // logging: true, // 是否啟用日志
}
module.exports = config

創(chuàng)建連接配置文件 connect.js

// 在connect.js文件中,使用sequelize連接數(shù)據(jù)庫(kù)
const config = require('./dbinfo') // 引入數(shù)據(jù)庫(kù)配置信息
const { Sequelize, DataTypes ,Op} = require("sequelize") // 引入sequelize依賴

const sequelize = new Sequelize(
    config.database,
    config.username,
    config.password,
    {
      dialect: config.dialect,
      dialectOptions: {
        dateStrings: true,
        typeCast: true
      },
      host: config.host,
      port: config.port,
      logging: config.logging,
      pool: { // 連接池配置
        min: 0, // 最小連接數(shù)
        max: 5, // 最大鏈接數(shù)
        idle: 30000,
        acquire: 60000,
      },
      define: {
        // 字段以下劃線(_)來分割(默認(rèn)是駝峰命名風(fēng)格)
        underscored: true
      },
      timezone: '+08:00'
    }
)

module.exports = {
  sequelize,// 將sequelize暴露出接口方便Model調(diào)用
  DataTypes,
  Op
}

創(chuàng)建模型

舉個(gè)例子绰筛,創(chuàng)建一個(gè)新聞表模型
./models/news.js

// 引入連接
const {
  sequelize,
  DataTypes
} = require('../config/connect')
const News = sequelize.define(
  'xx_news',
  {
    news_id: {
      type: DataTypes.INTEGER(11),
      allowNull: false, // 是否允許為空
      autoIncrement: true,
      primaryKey: true, // 是否主鍵
    },
    cover_img: {
      type: DataTypes.STRING,
      // allowNull: false,
      comment: '新聞列表項(xiàng)封面'
    },
    news_title: {
      type: DataTypes.STRING,
      allowNull: false,
      comment: '新聞標(biāo)題'
    },
    news_desc: {
      type: DataTypes.STRING,
      // allowNull: false,
      allowNull: false,
      comment: '新聞列表項(xiàng)簡(jiǎn)要描述'
    },
    news_content: {
      type: DataTypes.TEXT,
      // allowNull: false,
      comment: '新聞內(nèi)容'
    },
    is_hot: {
      type: DataTypes.BOOLEAN,
      // allowNull: false,
      allowNull: false,
      defaultValue: false,
      comment: '新聞是否熱門'
    },
    news_path: {
      type: DataTypes.STRING,
      allowNull: true,
      comment: '新聞訪問路徑'
    },
    state: {
      type: DataTypes.BOOLEAN, // 字段類型
      allowNull: false, // 是否允許為空
      defaultValue: false,
      comment: '狀態(tài):true/已發(fā)布,false/草稿'
    }
  }, {
    timestamps: true,
    // paranoid 模型, 軟刪除
    paranoid: true,
    // 如果要為 deletedAt 列指定自定義名稱
    deletedAt: 'destroy_time',
    // 不想要 createdAt
    createdAt: 'publish_time',
    
    // 想要 updatedAt 但是希望名稱叫做 updateTime
    updatedAt: 'update_time'
  }
)
// News.sync({force:true}) // 是否自動(dòng)創(chuàng)建表

module.exports = News

初始化
./models/index.js

const {
  sequelize,
  Op
} = require('../config/connect')
const News = require('./news')
sequelize.sync({ alter: true })
module.exports = {
  News
}

/*
// 標(biāo)準(zhǔn)同步
// 只有當(dāng)數(shù)據(jù)庫(kù)中不存在與模型同名的數(shù)據(jù)表時(shí)描融,才會(huì)同步
sequelize.sync()
// 動(dòng)態(tài)同步
// 修改同名數(shù)據(jù)表結(jié)構(gòu)铝噩,以適用模型。
sequelize.sync({alter: true})
// 強(qiáng)制同步
// 刪除同名數(shù)據(jù)表后同步窿克,謹(jǐn)慎使用骏庸,會(huì)導(dǎo)致數(shù)據(jù)丟失
sequelize.sync({force: true})

// 另外毛甲,當(dāng)你指定表與表之間的關(guān)聯(lián)后,修改被關(guān)聯(lián)的表結(jié)構(gòu)時(shí)會(huì)拋出異常具被。
// 需要先注釋掉關(guān)聯(lián)代碼玻募,然后更新同步模型后,再取消掉注釋即可一姿。

// 再另外七咧,當(dāng)你有新的關(guān)聯(lián)時(shí)必須使用動(dòng)態(tài)同步才會(huì)生效。

*/

先到這里叮叹,下回繼續(xù)艾栋。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市衬横,隨后出現(xiàn)的幾起案子裹粤,更是在濱河造成了極大的恐慌,老刑警劉巖蜂林,帶你破解...
    沈念sama閱讀 217,509評(píng)論 6 504
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異拇泣,居然都是意外死亡噪叙,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,806評(píng)論 3 394
  • 文/潘曉璐 我一進(jìn)店門霉翔,熙熙樓的掌柜王于貴愁眉苦臉地迎上來睁蕾,“玉大人,你說我怎么就攤上這事债朵∽涌簦” “怎么了?”我有些...
    開封第一講書人閱讀 163,875評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵序芦,是天一觀的道長(zhǎng)臭杰。 經(jīng)常有香客問我,道長(zhǎng)谚中,這世上最難降的妖魔是什么渴杆? 我笑而不...
    開封第一講書人閱讀 58,441評(píng)論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮宪塔,結(jié)果婚禮上磁奖,老公的妹妹穿的比我還像新娘。我一直安慰自己某筐,他們只是感情好比搭,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,488評(píng)論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著南誊,像睡著了一般身诺。 火紅的嫁衣襯著肌膚如雪蜜托。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,365評(píng)論 1 302
  • 那天戚长,我揣著相機(jī)與錄音盗冷,去河邊找鬼。 笑死同廉,一個(gè)胖子當(dāng)著我的面吹牛仪糖,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播迫肖,決...
    沈念sama閱讀 40,190評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼锅劝,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了蟆湖?” 一聲冷哼從身側(cè)響起故爵,我...
    開封第一講書人閱讀 39,062評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎隅津,沒想到半個(gè)月后诬垂,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,500評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡伦仍,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,706評(píng)論 3 335
  • 正文 我和宋清朗相戀三年结窘,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片充蓝。...
    茶點(diǎn)故事閱讀 39,834評(píng)論 1 347
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡隧枫,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出谓苟,到底是詐尸還是另有隱情官脓,我是刑警寧澤,帶...
    沈念sama閱讀 35,559評(píng)論 5 345
  • 正文 年R本政府宣布涝焙,位于F島的核電站卑笨,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏纱皆。R本人自食惡果不足惜个曙,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,167評(píng)論 3 328
  • 文/蒙蒙 一闺金、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦啄糙、人聲如沸铝宵。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,779評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至,卻和暖如春歧譬,著一層夾襖步出監(jiān)牢的瞬間岸浑,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,912評(píng)論 1 269
  • 我被黑心中介騙來泰國(guó)打工瑰步, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留矢洲,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,958評(píng)論 2 370
  • 正文 我出身青樓缩焦,卻偏偏與公主長(zhǎng)得像读虏,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子袁滥,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,779評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容