Node连接Mysql

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

安装Mysql模块

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

连接Mysql

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
复制代码
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

查询

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

添加

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

删除

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

更新

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

结束连接

1
2
3
4
复制代码
connection.end(function(err) {});
connection.destroy();
复制代码

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

封装

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

封装好的代码

1.数据库配置文件

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

2.封装、暴露方法

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
复制代码
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.演示实例

1
2
3
4
5
6
7
8
9
10
11
12
复制代码
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。

Node连接MySQL并封装其增删查改相关推荐

  1. mysql 查询和修改组合_## 超详细MySQL常用语句,增删查改

    ## MySQL常用语句,增删查改,安装配置mysql服务 ***#新手博客,应届生,谢谢支持哟 记得点赞关注哟*** ***-----sql常见命令:--------*** 安装服务:mysqld ...

  2. linux增删查改语句,mysql基础知识之增删查改使用介绍

    mysql基础知识之增删查改使用介绍 本文主要介绍mysql常用的SELECT.INSERT.UPDATE.DELETE语句的使用,数据库的安装这里不做介绍,并且事先已经准备好相关数据. 本文中使用的 ...

  3. MySQL表sql语句增删查改_学会这些操作你就不会栓Q(狗头)

    目录 本章目标 CRUD 新增(Create) 单行数据,全列插入 多行插入,指定列插入 查询(Retrieve) 修改(Update) 删除(Delete) 本章目标 学会MySQL表中的sql语句 ...

  4. 6000字总结MySQL最基础的增删查改命令

    文章目录 一.新增(Create) 1.单行数据 + 全列插入 2.多行数据 + 全列插入 3.多行数据+指定列插入 二.查询(Retrieve) 1.全列查询 2.指定列查询 3.查询字段为表达式 ...

  5. Node 连接Mysql并进行增删改查

    NPM: NPM的全称是Node Package Manager,类似于ruby的gem,Python的PyPL.setuptools,PHP的pear,是Nodejs中的包管理器.Nodejs自身提 ...

  6. Java培优班 - 第二十天、第二十一天 - JavaWeb - Part 1: 课程 - MySQL(理论常识 + 增删查改 + 数据类型 + 备份/恢复 ) -(较全)

    文章目录 1.1数据库概述 1.1.1什么是数据库? 1.1.2什么是关系型数据库\color{#ff0011}{关系型数据库}关系型数据库? 1.1.3数据库相关概念\color{#ff0011}{ ...

  7. mysql scrapy 重复数据_scrapy关于将数据保存进mysql数据库及问题解决(增删查改)

    importpymysqlfrom scrapy.utils.project import get_project_settings#引入settings配置 classDBHelper():def ...

  8. mysql菜鸟指南(增删查改、数据类型、常用命令)

    1.连接数据库 [root@host]# mysql -u root -p Enter password:****** 2.查看数据库 SHOW DATABASES; 3.创建数据库 mysql> ...

  9. django与mysql实现增删_django与mysql实现简单的增删查改

    模型定义 from django.db import models class Grades(models.Model): g_name = models.CharField(max_length=2 ...

最新文章

  1. go的http包详解
  2. Python logging模块日志存储位置踩坑
  3. 修改maven打包名字
  4. Qt图形界面编程入门(6)
  5. android中给button加图标,Android,如何在我的代码中的TabButton中添加图标
  6. 离你最近的疫情小区,终于可以自己查了!
  7. Object中的clone方法
  8. Atitit 返回http500返回码,以及自定义返回提示 目录 1. 可以看到从php发送http响应代码的三种方法: 1 1.1. Header(HTTP/1.1 404 Not Found
  9. Spring Cloud Alibaba Sentinel之入门篇
  10. C# WPF 高级教程
  11. XcodeGhost事件冷思考:智能时代的达摩克利斯之剑
  12. composer 安装laravel
  13. 推荐给大家的桌面管理软件: Fences
  14. 操作系统——进程管理(进程的概念与进程控制)
  15. IT是什么意思?什么是IT行业?
  16. 零基础学前端系列教程 | 和前端谈恋爱的第005天——约会账单
  17. 下载Eclipse压缩包
  18. 红豆角源码--红豆角系统红豆角APP拼团系统源码分享
  19. 22考研全年备考规划表,这5个时间点你必须知道!
  20. idea的简单使用,初始化过程

热门文章

  1. RAID入门一页通,最全的RAID技术、原理图解
  2. 【 D3.js 入门系列 --- 7 】 理解 update, enter, exit 的使用
  3. 使用as3crypto在Flex中实现AES加密
  4. centoss7 yum 安装 wget
  5. 使用 ale.js 制作一个小而美的表格编辑器(4)
  6. 《模式识别原理及工程应用》——第2章 基于贝叶斯决策理论的分类器 2.1 分类器的描述方法...
  7. 分布式监控系统Zabbix-3.0.3-完整安装记录(4)-解决zabbix监控图中出现中文乱码问题...
  8. 推荐!可视化垃圾回收算法(转)
  9. 独家披露51CTO被黑过程:数据库已小范围流传
  10. 大湾区足球联赛港澳赛区上演进球大战