node mysql封装_Node连接MySQL并封装其增删查改

9f7a67f00933d593b8ac279e05665535.png

Node连接Mysql

说到node,可能大家会想到MOngoDB作为数据库,这里将会介绍node与mysql的连接,并分享了封装好的实例代码,在项目开发中可直接使用。下一篇博客将会讲node连接MongoDB。

安装Mysql模块

npm install mysql

连接Mysql

const mysql = require('mysql');

let connection = mysql.createConnection({

host : 'localhost',

user : 'root',

password : 'password',

database : 'test'

});

connection.connect(function(err) {

if (err) {

console.error('连接失败: ' + err.stack);

return;

}

console.log('连接成功 id ' + connection.threadId);

});

host:连接的服务器

user:数据库用户名

password:设置的MySQL密码

database: 要连接的数据库名

常用的SQL语句

具体的使用这里不做详细说明,包括select、insert、update、delete等语句。

Node操作Mysql

查询

connection.query('SELECT * FROM t_user WHERE username = "whg"', (err, results, fields) => {

if(err){

console.log(err);

}

console.log(results);

})

添加

connection.query('INSERT INTO t_user(username, pass) VALUES(?, ?)',['whg', '123'], (err, results) => {

if(err){

console.log(err);

}

console.log(results);

})

删除

connection.query('DELETE FROM t_user WHERE id = 1', (err, results) => {

if(err){

console.log(err);

}

console.log(results);

})

更新

connection.query('UPDATE t_user SET pass = "321" WHERE username = "whg"', (err, results) => {

if(err){

console.log(err);

}

console.log(results);

})

结束连接

connection.end(function(err) {

});

connection.destroy();

这两种都行,第二种是强制结束。

封装

说了这么多,感觉操作起来还是挺简单的。在实际开发中,我们想要操作起来更方便,那就让我们自己封装一下来使用。直接上代码:

封装好的代码

1.数据库配置文件

//配置链接数据库参数

module.exports = {

host : 'localhost',

port : 3306,//端口号

database : 'nodetest',//数据库名

user : 'root',//数据库用户名

password : '123456'//数据库密码

};

2.封装、暴露方法

let mysql = require('mysql');//引入mysql模块

var databaseConfig = require('./mysql.config'); //引入数据库配置模块中的数据

//向外暴露方法

module.exports = {

query : function(sql,params,callback){

//每次使用的时候需要创建链接,数据操作完成之后要关闭连接

var connection = mysql.createConnection(databaseConfig);

connection.connect(function(err){

if(err){

console.log('数据库链接失败');

throw err;

}

//开始数据操作

//传入三个参数,第一个参数sql语句,第二个参数sql语句中需要的数据,第三个参数回调函数

connection.query( sql, params, function(err,results,fields ){

if(err){

console.log('数据操作失败');

throw err;

}

//将查询出来的数据返回给回调函数

callback && callback(results, fields);

//results作为数据操作后的结果,fields作为数据库连接的一些字段

//停止链接数据库,必须再查询语句后,要不然一调用这个方法,就直接停止链接,数据操作就会失败

connection.end(function(err){

if(err){

console.log('关闭数据库连接失败!');

throw err;

}

});

});

});

}

};

3.演示实例

var db=require('../model/mysql.js');

// 查询实例

db.query('select * from t_user', [],function(result,fields){

console.log('查询结果:');

console.log(result);

});

//添加实例

var addSql = 'INSERT INTO websites(username,password) VALUES(?,?)';

var addSqlParams =['咕噜先森', '666'];

db.query(addSql,addSqlParams,function(result,fields){

console.log('添加成功')

})

结束

想要使用的朋友,可以直接把封装好的两个文件copy到项目中,改一下配置就可以使用了,大大提高开发效率。下一篇将会分享Node连接MongoDB。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值