Nodejs 第三十九章(knex)

Nodejs 第三十九章(knex)本文介绍了 Knex 一个用于生成和执行 SQL 查询的 JavaScript 库 展示了如何安装 配置 定义表结构 执行 CRUD 操作以及处理事务

大家好,欢迎来到IT知识分享网。

knex

Knex是一个基于JavaScript的查询生成器,它允许你使用JavaScript代码来生成和执行SQL查询语句。它提供了一种简单和直观的方式来与关系型数据库进行交互,而无需直接编写SQL语句。你可以使用Knex定义表结构、执行查询、插入、更新和删除数据等操作。

https://knexjs.org/guide/query-builder.html#withrecursive

Knex的安装和设置

knex支持多种数据库 pg sqlite3 mysql2 oracledb tedious

用什么数据库安装对应的数据库就行了

#安装knex $ npm install knex --save #安装你用的数据库 $ npm install pg $ npm install pg-native $ npm install sqlite3 $ npm install better-sqlite3 $ npm install mysql $ npm install mysql2 $ npm install oracledb $ npm install tedious 

连接数据库

import knex from 'knex' const db = knex({ 
    client: "mysql2", connection: config.db }) 
db: user: root password: '' host: localhost port: 3306 database: xiaoman 

定义表结构

db.schema.createTable('list', (table) => { 
    table.increments('id') //id自增 table.integer('age') //age 整数 table.string('name') //name 字符串 table.string('hobby') //hobby 字符串 table.timestamps(true,true) //创建时间和更新时间 }).then(() => { 
    console.log('创建成功') }) 

实现增删改差

import mysql2 from 'mysql2/promise' import fs from 'node:fs' import jsyaml from 'js-yaml' import express from 'express' import knex from 'knex' const yaml = fs.readFileSync('./db.config.yaml', 'utf8') const config = jsyaml.load(yaml) // const sql = await mysql2.createConnection({ 
    // ...config.db // }) const db = knex({ 
    client: "mysql2", connection: config.db }) const app = express() app.use(express.json()) //查询接口 全部 app.get('/', async (req, res) => { 
    const data = await db('list').select().orderBy('id', 'desc') const total = await db('list').count('* as total') res.json({ 
    code: 200, data, total: total[0].total, }) }) //单个查询 params app.get('/user/:id', async (req, res) => { 
    const row = await db('list').select().where({ 
    id: req.params.id }) res.json({ 
    code: 200, data: row }) }) //新增接口 app.post('/create', async (req, res) => { 
    const { 
    name, age, hobby } = req.body const detail = await db('list').insert({ 
    name, age, hobby }) res.send({ 
    code: 200, data: detail }) }) //编辑 app.post('/update', async (req, res) => { 
    const { 
    name, age, hobby, id } = req.body const info = await db('list').update({ 
    name, age, hobby }).where({ 
    id }) res.json({ 
    code: 200, data: info }) }) //删除 app.post('/delete', async (req, res) => { 
    const info = await db('list').delete().where({ 
    id: req.body.id }) res.json({ 
    code: 200, data: info }) }) const port = 3000 app.listen(port, () => { 
    console.log(`Example app listening on port ${ 
     port}`) }) 

事务

你可以使用事务来确保一组数据库操作的原子性,即要么全部成功提交,要么全部回滚

例如A给B转钱,需要两条语句,如果A语句成功了,B语句因为一些场景失败了,那这钱就丢了,所以事务就是为了解决这个问题,要么都成功,要么都回滚,保证金钱不会丢失。

//伪代码 db.transaction(async (trx) => { 
    try { 
    await trx('list').update({ 
   money: -100}).where({ 
    id: 1 }) //A await trx('list').update({ 
   money: +100}).where({ 
    id: 2 }) //B await trx.commit() //提交事务 } catch (err) { 
    await trx.rollback() //回滚事务 } }) 

免责声明:本站所有文章内容,图片,视频等均是来源于用户投稿和互联网及文摘转载整编而成,不代表本站观点,不承担相关法律责任。其著作权各归其原作者或其出版社所有。如发现本站有涉嫌抄袭侵权/违法违规的内容,侵犯到您的权益,请在线联系站长,一经查实,本站将立刻删除。 本文来自网络,若有侵权,请联系删除,如若转载,请注明出处:https://haidsoft.com/155699.html

(0)
上一篇 2025-02-17 18:15
下一篇 2025-02-17 18:20

相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注微信