Nodejs学习笔记(一)--- 操作Mysql数据库
对于一门语言的学习,我个人觉得最好的方式就是通过一个项目来展示,所以从基本的一些模块去了解是最好的方式对于Mysql怎么去链接数据库这个我是在网上找到的(其实一直想找官方文档的,发现没有它的踪迹,(后续找到之后还是建议去看官方文档,毕竟那才是最正式的内容),好了,废话不多说,就来进入我今天所学的主题;
实现来一个简单的例子
在自己的项目的根目录下执行 npm install mysql (安装mysql的依赖)
一 建立连接
var mysql = require('mysql'); var connection = mysql.createConnection( {
host: '127.0.0.1',
user: 'root',
password: 'root',
port: '',
database: 'mysql'
}) // 创建一个连接
connection.connect(function(err) {
if (err) {
console.log(err);
return;
}
console.log('mysql connect success')
}) // 执行sql语句
connection.query('select count(*) as num from user', function (err, rows) {
if (err) {
console.log('query error:' + err)
return;
}
console.log('connection result:' + JSON.stringify(rows))
}) // 关闭连接
connection.end(function(err) {
if(err) {
console.log('connection end:' + err);
return;
}
console.log('connection close')
})
解释: 其中连接的过程就如上所诉,其中创建连接的时候的字段
host:主机地址 (默认:localhost)
user:用户名
password:密码
port:端口号 (默认:3306)
database:数据库名
charset:连接字符集(默认:'UTF8_GENERAL_CI',注意字符集的字母都要大写)
localAddress:此IP用于TCP连接(可选)
socketPath:连接到unix域路径,当使用 host 和 port 时会被忽略
timezone:时区(默认:'local')
connectTimeout:连接超时(默认:不限制;单位:毫秒)
stringifyObjects:是否序列化对象(默认:'false' ;与安全相关)
typeCast:是否将列值转化为本地JavaScript类型值 (默认:true)
queryFormat:自定义query语句格式化方法
supportBigNumbers:数据库支持bigint或decimal类型列时,需要设此option为true (默认:false)
bigNumberStrings:supportBigNumbers和bigNumberStrings启用 强制bigint或decimal列以JavaScript字符串类型返回(默认:false)
dateStrings:强制timestamp,datetime,data类型以字符串类型返回,而不是JavaScript Date类型(默认:false)
debug:开启调试(默认:false)
multipleStatements:是否许一个query中有多个MySQL语句 (默认:false)
flags:用于修改连接标志
ssl:使用ssl参数(与crypto.createCredenitals参数格式一至)或一个包含ssl配置文件名称的字符串,目前只捆绑Amazon RDS的配置文件
二 实现增删改查
连接建立了,接下就来实现最简单的增删改查
数据库
create table userInfo(
uid int(11) not null,
uname varchar(20),
primary key (uid)
);
var mysql = require('mysql'); var connection = mysql.createConnection( {
host: '47.93.34.145',
user: 'root',
password: 'root',
port: '3306',
database: 'mysql'
}) // 创建一个连接
connection.connect(function(err) {
if (err) {
console.log(err);
return;
}
console.log('mysql connect success')
}) // 执行新增sql语句
connection.query("insert into userInfo values('1', 'yaobo')", function (err, rows) {
if (err) {
console.log('query error:' + err)
return;
}
console.log('success !!!');
})
// // 执行查询sql语句
connection.query('select * from userInfo', function (err, rows) {
if (err) {
console.log('error:' + err)
return;
}
console.log('query result:' + JSON.stringify(rows))
})
// 执行修改sql语句
connection.query("update userInfo set uname='yaobo1'", function (err, rows) {
if (err) {
console.log('error:' + err)
return;
}
console.log('update success !!!');
})
// 执行sql语句
connection.query('delete from userInfo', function (err, rows) {
if (err) {
console.log('error:' + err)
return;
}
console.log('delete success !!!')
}) // 关闭连接
connection.end(function(err) {
if(err) {
console.log('connection end:' + err);
return;
}
console.log('connection close')
})
三 实现连接池
在实际项目中,连接池运用是非常广泛的,他能同时保证多个连接不受影响,极大的提高了运行效率,接下来就来看下nodejs 下是怎么实现的
var mysql = require('mysql'); var pool = mysql.createPool( {
host: '47.93.34.145',
user: 'root',
password: 'root',
port: '3306',
database: 'mysql'
}) pool.on('connection', function (connection) {
// 设置服务器session 会话自增长
connection.query('SET SESSION auto_increment_increment=1')
}) // 直接使用 (这样写不建议, 每次使用完之后建议释放)
pool.query('select * from userInfo', function (er, rows) {
if (er) {
console.log('er:' + er)
}
console.log('connection result:' + JSON.stringify(rows))
}) // 共享 (建议这样写)
pool.getConnection(function(err, connection) {
// 这一波还阔以共享
connection.query('select * from userInfo', function (er, rows) {
if (er) {
console.log('er:' + er)
}
console.log('connection result:' + JSON.stringify(rows))
})
})
其中创建连接池还有一些其他的参数如下:
waitForConnections
当连接池没有连接或超出最大限制时,设置为true且会把连接放入队列,设置为false会返回error
connectionLimit
连接数限制,默认:10
queueLimit
最大连接请求队列限制,设置为0表示不限制,默认:0
Nodejs学习笔记(一)--- 操作Mysql数据库的更多相关文章
- python学习笔记之——操作mysql数据库
Python 标准数据库接口为 Python DB-API,Python DB-API为开发人员提供了数据库应用编程接口. Python 数据库接口支持非常多的数据库,你可以选择适合你项目的数据库: ...
- Python学习笔记9-Python 链接MySql数据库
Python 链接MySql数据库,方法很简单: 首先需要先 安装一个MySql链接插件:MySQL-python-1.2.3.win-amd64-py2.7.exe 下载地址:http://dev. ...
- C#学习笔记---C#操作SQL数据库
C#操作SQL数据库 Connection(连接)对象 连接字符串: 形式1.”server=;uid=;pwd=;database=” 形式2.”server=;Intergrated Securi ...
- C++学习笔记13_操作MySql
1. 链接Mysql #include <winsock.h>#include "mysql.h"#include <stdlib.h>#include & ...
- robot framework学习笔记之七—连接mysql数据库
1.安装Database-Library 输入命令:pip install robotframework_databaselibrary 2.添加Database的Library 3.实例 * ...
- 全栈项目|小书架|服务器开发-NodeJS 中使用 Sequelize 操作 MySQL数据库
安装 官网:https://sequelize.org/v5/manual/getting-started.html 安装sequelize及数据库连接驱动 npm install --save se ...
- golang学习笔记16 beego orm 数据库操作
golang学习笔记16 beego orm 数据库操作 beego ORM 是一个强大的 Go 语言 ORM 框架.她的灵感主要来自 Django ORM 和 SQLAlchemy. 目前该框架仍处 ...
- openresty 学习笔记四:连接mysql和进行相关操作
openresty 学习笔记四:连接mysql和进行相关操作 毕竟redis是作为缓存,供程序的快速读写,虽然reidis也可以做持久化保存,但还是需要一个做数据存储的数据库.比如首次查询数据在red ...
- php笔记08:数据库编程---使用php的MySQL扩展库操作MySQL数据库
1.使用php的MySQL扩展库操作MySQL数据库: php有3种方式操作MySQL数据库 (1)mysql扩展库 (2)mysqli扩展库 (3)pdo mysql扩展库与mysql数据库 ...
- Nodejs学习笔记(十五)--- Node.js + Koa2 构建网站简单示例
目录 前言 搭建项目及其它准备工作 创建数据库 创建Koa2项目 安装项目其它需要包 清除冗余文件并重新规划项目目录 配置文件 规划示例路由,并新建相关文件 实现数据访问和业务逻辑相关方法 编写mys ...
随机推荐
- sql 事务处理 与 try catch
begin transaction tr declare @error int; ; select * from Car_Brand set @error=@error+@@ERROR set @er ...
- PHP接收post请求,不是空数组就是没值,怎么办!
使用: $_POST $_REQUEST I('post.') 都不行, 换成: file_get_contents("php://input");
- hadoop分布式安装及其集群配置笔记
各机器及角色信息: 共10台机器,hostname与ip地址映射在此不做赘述.此为模拟开发环境安装,所以不考虑将NameNode和SecondaryNameNode安装在同一台机器. 节点 角色 na ...
- Python学习手册之Python介绍、基本语法(一)
一.什么是python? python是一种高级的编程语言.它适合编写一些应用程序,比如:网站编程,脚本编程,科学计算和最近非常热门的AI(人工智能).目前,Google,腾讯,百度,阿里巴巴,豆瓣都 ...
- Mac使用bootcamp安装win系统花屏解决方法
15年11'乞丐版air装win屏幕花屏,很郁闷,先后找了网上很多方法,最终总结出了一个比较折中的方法,不玩游戏不使用大型3D的可以参考. 1 花屏现象 2 解决方法 2.1 禁用驱动 2.2 使用M ...
- Go 跨域请求问题
在使用go语言写测试服务的时候遇到了前端跨域请求问题,只需在go中加入 w.Header().Set("Access-Control-Allow-Origin", "*& ...
- Tokio,Rust异步编程实践之路
缘起 在许多编程语言里,我们都非常乐于去研究在这个语言中所使用的异步网络编程的框架,比如说Python的 Gevent.asyncio,Nginx 和 OpenResty,Go 等,今年年初我开始接触 ...
- xshell sftp可用命令,sftp: cannot open d: to write![解决]
sftp可用命令: cd 路径 更改远程目录到“路径” lcd 路径 更改本地目录到“路径” chgrp group path 将文件“path”的组更改为“group” chmod mode pat ...
- 20155302 实验三 敏捷开发与XP实践
20155302 实验三 敏捷开发与XP实践 实验内容 XP基础 XP核心实践 相关工具 实验内容及步骤 (一)编码标准 在IDEA中使用工具(Code->Reformate Code)把代码重 ...
- Phaser Matter Collision Plugin 碰撞插件 -- iFiero技术分享
collision-simple-demo Phaser 自带的Arcade虽然易用,但复杂的物理碰撞明显就不够用了,于是Matter等物理引擎还是不得不学的,以下是Matter物理体碰撞的一个插件, ...