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 ...
随机推荐
- 用GO写一个后台权限管理系统
最近用GO写了一个后台权限管理系统,在WIN10和ubuntu下部署,在win系统下编译ububtu的部署文件要先做如下配置 set GOARCH=amd64 set GOOS=linux go bu ...
- 20155211 《Java程序设计》实验一(Java开发环境的熟悉)实验报告
20155211 <Java程序设计>实验一(Java开发环境的熟悉)实验报告 一.实验内容及步骤 (一)使用JDK编译.运行简单的java程序 命令行下的程序开发 步骤一(新建文件夹): ...
- 20155322 《Java程序设计》课堂实践项目MyOD
20155322 <Java程序设计>课堂实践项目MyOD 实践要求 编写MyOD.java 用java MyOD XXX实现Linux下od -tx -tc XXX的功能 提交测试代码和 ...
- 初识Linux的感受与对它的印象——20155328张钰清
之前从未接触过虚拟机的我,由于这次寒假预备作业,稍稍地认识了一下Linux操作系统. 在自己笔记本上安装Linux操作系统 根据老师提供的<基于VirtualBox虚拟机安装Ubuntu图文教程 ...
- 20155333 2016-2017-2 《Java程序设计》第三周学习总结
20155333 2016-2017-2 <Java程序设计>第三周学习总结 教材学习内容总结 第四章 类定义时使用class关键词,名称使用Clothes,建立实例要使用new关键词. ...
- tkinter界面卡死的解决办法
0.如果点击按钮,运行了一个比较耗时的操作,那么界面会卡死 import tkinter as tk import time def onclick(text, i): time.sleep(3) t ...
- LumiSoft.Net 收发邮件
一:LumiSoft.Net简介 Lumisoft is a software development company specialised in mobile phones and tablets ...
- nginx交替出现404和200
今天在调试接口的时候,发现一个奇怪的问题,服务器接口交替返回404和200错误. 排查的时候发现nginx下有大量的404错误记录,而tomcat有两个,一个有正常的访问记录,而另一个虽然启动正常,但 ...
- Unity Lighting - High Dynamic Range (HDR) 高动态范围(五)
High Dynamic Range (HDR) 高动态范围 As well as Color Space, the ‘dynamic range’ of your camera needs to ...
- 基于zookeeper+mesos+marathon的docker集群管理平台
参考文档: mesos:http://mesos.apache.org/ mesosphere社区版:https://github.com/mesosphere/open-docs mesospher ...