博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Node连接MySQL并封装其增删查改
阅读量:5974 次
发布时间:2019-06-19

本文共 3284 字,大约阅读时间需要 10 分钟。

Node连接Mysql

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

安装Mysql模块

1复制代码
npm install mysql复制代码

连接Mysql

1234567891011121314151617复制代码
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

查询

123456复制代码
connection.query('SELECT * FROM t_user WHERE username = "whg"', (err, results, fields) => {    if(err){        console.log(err);    }    console.log(results);})复制代码

添加

123456复制代码
connection.query('INSERT INTO t_user(username, pass) VALUES(?, ?)',['whg', '123'], (err, results) => {    if(err){        console.log(err);    }    console.log(results);})复制代码

删除

123456复制代码
connection.query('DELETE FROM t_user  WHERE id = 1', (err, results) => {    if(err){        console.log(err);    }    console.log(results);})复制代码

更新

123456复制代码
connection.query('UPDATE t_user SET pass = "321" WHERE username = "whg"', (err, results) => {    if(err){        console.log(err);    }    console.log(results);})复制代码

结束连接

1234复制代码
connection.end(function(err) {  });connection.destroy();复制代码

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

封装

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

封装好的代码

1.数据库配置文件

12345678复制代码
//配置链接数据库参数module.exports = {    host : 'localhost',    port : 3306,//端口号    database : 'nodetest',//数据库名    user : 'root',//数据库用户名    password : '123456'//数据库密码};复制代码

2.封装、暴露方法

12345678910111213141516171819202122232425262728293031323334复制代码
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.演示实例

123456789101112复制代码
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。

转载地址:http://yzdox.baihongyu.com/

你可能感兴趣的文章
修改notepad++的主题(背景色、前景色、字体等)
查看>>
常用模块-random,shutil,shevle,logging
查看>>
C# 可变数量参数的使用
查看>>
了解断言
查看>>
Web架构
查看>>
嵌入式C语言自我修养 01:Linux 内核中的GNU C语言语法扩展
查看>>
python list 线性访问和随机访问比较
查看>>
python笔记(三)---文件读写、修改文件内容、处理json、函数
查看>>
jdk安装
查看>>
[九省联考2018]IIIDX
查看>>
Mysql学习总结(10)——MySql触发器使用讲解
查看>>
C# XML与对象互相转换
查看>>
Java中如何使封装自己的类,建立并使用自己的类库?
查看>>
spring 源代码地址
查看>>
为什么是List list = new ArrayList() 而不直接用ArrayList
查看>>
mingw64环境搭建
查看>>
R中,数据标准化方法
查看>>
Batch update
查看>>
带有重复元素的旋转数组的处理
查看>>
我的人工智能机器人的游戏
查看>>