node.js 开发指南 ? Node.js 连接 MySQL 并进行数据库操作


Posted in Javascript onJuly 29, 2014

Node.js是一套用来编写高性能网络服务器的JavaScript工具包
 
通常在NodeJS开发中我们经常涉及到操作数据库,尤其是 MySQL ,作为应用最为广泛的开源数据库则成为我们的首选,本篇就来介绍下如何通过NodeJS来操作 MySQL 数据库。 安装MySQL模块到NodeJS中 我们需要让NodeJS支持MySQL,则需要将MySQL模块添加到系统支持库
 
想要快速了解Node.js ,赞生推荐亲看看 node.js_guide.pdf  — node.js 开发指南 :想要电子版高清的 留言发送
 
如果不想留言 可以带你做飞机! 直接下载
 
Node.js
简单介绍一下node.js的操作吧
安装 node-mysql
C代码  

$ npm install mysql

 
创建测试表
//数据库名 NodeSample
C代码  

CREATE TABLE `NodeSample`.`MyTable` ( 
`id` INT UNSIGNED NOT NULL AUTO_INCREMENT PRIMARY KEY , 
`firstname` VARCHAR( 20 ) NOT NULL , 
`lastname` VARCHAR( 20 ) NOT NULL , 
`message` TEXT NOT NULL 
) ENGINE = MYISAM ;

 
连接数据库
Js代码  

var sys = require('sys'); 
 
var Client = require('mysql').Client; 
var client = new Client(); 
 
client.user = 'someuser'; 
client.password = 'password'; 
 
client.connect(function(error, results) { 
if(error) { 
console.log('Connection Error: ' + error.message); 
return; 
} 
console.log('Connected to MySQL'); 
});

 
打开数据库
Js代码  

ClientConnectionReady = function(client) 
{ 
client.query('USE NodeSample', function(error, results) { 
if(error) { 
console.log('ClientConnectionReady Error: ' + error.message); 
client.end(); 
return; 
} 
}); 
};

 
完成数据库操作程序
Js代码 

var sys = require('sys'); 
 
var Client = require('mysql').Client; 
var client = new Client(); 
 
client.user = 'someuser'; 
client.password = 'password'; 
 
console.log('Connecting to MySQL...'); 
 
client.connect(function(error, results) { 
if(error) { 
console.log('Connection Error: ' + error.message); 
return; 
} 
console.log('Connected to MySQL'); 
ClientConnectionReady(client); 
}); 
 
ClientConnectionReady = function(client) 
{ 
client.query('USE NodeSample', function(error, results) { 
if(error) { 
console.log('ClientConnectionReady Error: ' + error.message); 
client.end(); 
return; 
} 
ClientReady(client); 
}); 
}; 
 
ClientReady = function(client) 
{ 
var values = ['Chad', 'Lung', 'Hello World']; 
client.query('INSERT INTO MyTable SET firstname = ?, lastname = ? , message = ?', values, 
function(error, results) { 
if(error) { 
console.log("ClientReady Error: " + error.message); 
client.end(); 
return; 
} 
console.log('Inserted: ' + results.affectedRows + ' row.'); 
console.log('Id inserted: ' + results.insertId); 
} 
); 
GetData(client); 
} 
 
GetData = function(client) 
{ 
client.query( 
'SELECT * FROM MyTable', 
function selectCb(error, results, fields) { 
if (error) { 
console.log('GetData Error: ' + error.message); 
client.end(); 
return; 
} 
// Uncomment these if you want lots of feedback 
//console.log('Results:'); 
//console.log(results); 
//console.log('Field metadata:'); 
//console.log(fields); 
//console.log(sys.inspect(results)); 
 
if(results.length > 0) 
{ 
var firstResult = results[0]; 
console.log('First Name: ' + firstResult['firstname']); 
console.log('Last Name: ' + firstResult['lastname']); 
console.log('Message: ' + firstResult['message']); 
} 
}); 
 
client.end(); 
console.log('Connection closed'); 
};
Javascript 相关文章推荐
验证控件与Button的OnClientClick事件详细解析
Dec 04 Javascript
Javascript基础教程之数据类型转换
Jan 18 Javascript
JavaScript插件化开发教程 (二)
Jan 27 Javascript
浅谈js内置对象Math的属性和方法(推荐)
Sep 19 Javascript
vuejs 单文件组件.vue 文件的使用
Jul 28 Javascript
vue.js中created方法作用
Mar 30 Javascript
webpack热模块替换(HMR)/热更新的方法
Apr 05 Javascript
vue+jquery+lodash实现滑动时顶部悬浮固定效果
Apr 28 jQuery
jQuery实现百度图片移入移出内容提示框上下左右移动的效果
Jun 05 jQuery
JS简易计算器实例讲解
Jun 30 Javascript
vue项目使用$router.go(-1)返回时刷新原来的界面操作
Jul 26 Javascript
Nuxt的路由配置和参数传递方式
Nov 06 Javascript
js返回前一页刷新本页重载页面
Jul 29 #Javascript
extjs 如何给column 加上提示
Jul 29 #Javascript
extjs 分页使用jsp传递数据示例
Jul 29 #Javascript
把文本中的URL地址转换为可点击链接的JavaScript、PHP自定义函数
Jul 29 #Javascript
JavaScript eval() 函数介绍及应用示例
Jul 29 #Javascript
javascript从image转换为base64位编码的String
Jul 29 #Javascript
javascript自定义函数参数传递为字符串格式
Jul 29 #Javascript
You might like
Discuz批量替换帖子内容的方法(使用SQL更新数据库)
2014/06/23 PHP
PHP-Java-Bridge使用笔记
2014/09/22 PHP
微信小程序发送订阅消息的方法(php 为例)
2019/10/30 PHP
JQuery的Validation插件中Remote验证的中文问题
2010/07/26 Javascript
EasyUi tabs的高度与宽度根据IE窗口的变化自适应代码
2010/10/26 Javascript
javascript语言结构小记(一)
2011/09/10 Javascript
Thinkphp模板没有解析直接原样输出的解决方法
2014/10/31 Javascript
详谈jQuery中使用attr(), prop(), val()获取value的异同
2017/04/25 jQuery
用Vue-cli搭建的项目中引入css报错的原因分析
2017/07/20 Javascript
微信小程序promsie.all和promise顺序执行
2017/10/27 Javascript
使用async-validator编写Form组件的方法
2018/01/10 Javascript
vuex 的简单使用
2018/03/22 Javascript
Element-ui DatePicker显示周数的方法示例
2019/07/19 Javascript
layui table 列宽百分比显示的实现方法
2019/09/28 Javascript
微信小程序实现限制用户转发功能的实例代码
2020/02/22 Javascript
Vue + element 实现多选框组并保存已选id集合的示例代码
2020/06/03 Javascript
vue+iview实现分页及查询功能
2020/11/17 Vue.js
[37:29]完美世界DOTA2联赛PWL S2 LBZS vs Forest 第二场 11.19
2020/11/19 DOTA
Python获取服务器信息的最简单实现方法
2015/03/05 Python
浅谈function(函数)中的动态参数
2017/04/30 Python
python使用RNN实现文本分类
2018/05/24 Python
python中int与str互转方法
2018/07/02 Python
Django框架的使用教程路由请求响应的方法
2018/07/03 Python
PyTorch中常用的激活函数的方法示例
2019/08/20 Python
tensorflow 获取所有variable或tensor的name示例
2020/01/04 Python
美国女性服饰销售网站:Nasty Gal(坏女孩)
2016/07/26 全球购物
ORACLE第二个十问
2013/12/14 面试题
致百米运动员广播稿
2014/01/29 职场文书
缅怀革命先烈演讲稿
2014/05/14 职场文书
保护环境标语
2014/06/09 职场文书
干部作风整顿个人剖析材料
2014/10/06 职场文书
2014年综治维稳工作总结
2014/11/17 职场文书
2015年骨干教师工作总结
2015/05/26 职场文书
母婴行业实体、电商模式全面解析
2019/08/01 职场文书
Golang 实现 WebSockets 之创建 WebSockets
2022/04/24 Golang
二维码条形码生成的JavaScript脚本库
2022/07/07 Javascript