nodejs 中使用 mysql 实现 crud

首先要使用 mysql 就必须要安装

npm install mysql

然后封装 sql 函数

const mySql = require('mysql');

let connection ;

let insert, update, deletes, select;
insert = update = deletes = select = (condition, callback) => {
 // insert into 表名(`name`,`age`) values('张三',12),('李四',13)
 // select * from 表名 where id=1 and name='张三'
 // update 表名 set name='张三' where id=1
 // delete from 表名 where id=1
  connection.query(condition, (err, data) => {
    if (err) throw err;
    callback && callback(data);
  });
};

// 或使用占位符的方式

insert = (sql, values, callback) => {
// 单条数据插入
  // sql:'insert into 表名 set ?'
  // values:{name: '张三', age:14}
  connection.query(sql, values, (err, data) => { 
    if (err) throw err; 
    callback && callback(data); 
  });

// 多条数据插入
  // sql:'insert into 表名(`name`,`age`) values ?'
  // values:[['张三', 18],['李四', 19],['王五', 20]]
  connection.query(sql, [values], (err, data) => { 
    if (err) throw err; 
    callback && callback(data); 
  });
}

update = (sql, values, callback) => { 
// 注意:mysql 没有批量 update 的方法,得使用循环来单个修改
// 更新单条数据
  // sql:'update 表名 set name=?,age=? where id=?'
  // values:['张三', 14, 1]
  connection.query(sql, values, (err, data) => { 
    if (err) throw err;
    callback && callback(data);
  });
// 更新全部数据
  // sql:'update 表名 set name=?'
  // values:['张三']
  connection.query(sql, values, (err, data) => {
    if(err) throw err;
    callback && callback(data);
  })
};

select = (sql, values, callback) => {  
// 多条件查询
  // sql:'select * from 表名 where name = ? and age = ?'
  // 或 sql:'select * from 表名 where name = ? or age = ?'
  // values:['张三', 12]
  connection.query(sql, values, (err, data) => { 
    if (err) throw err; 
    callback && callback(data); 
  }); 
// 同条件限定查询
  // sql:'select * from 表名 where id in (?)'
  // values:[1,2,3,4]
  connection.query(sql, [values], (err, data)=>{
    if(err) throw err;
    callback && callback(data)
  })

};

deletes = (sql, values, callback) =>{
// 删除一条
  // sql:'delete from 表名 where id=?'
  // values:[1]
  connnection.query(sql, values, (err, data)=>{
    if(err) throw err;
    callback && callback(data);
  })

// 删除多条
  // sql:'delete from 表名 where id in (?)'
  // values:[1,2,3]

  connection.query(sql, [values], (err, data) => {
    if(err) throw err;
    callback && callback(data)
  });
};

const connectionStart = callback => {
  connection = mySql.createConnection({
    host: 'localhost',
    user: 'root',
    password: '',
    database: 'bms-test-back'
  });
  connection.connect(err => {
    if (err) return console.log('connectSql fail:' + err);
    callback && callback();
  });
};

const connectionEnd = () => connection.end();


module.exports = {
  insert,
  update,
  deletes,
  select,
  connectionStart,
  connectionEnd
}

 

最后要在哪个 js 文件中使用,引入即可

转载于:https://www.cnblogs.com/xiaoyaoxingchen/p/11017336.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值