nodejs mysql 数据查询例子

时间 2014-11-11 15:28:01  姜糖水原文  http://www.cnphp6.com/archives/59864

1、安装nodejs

2、安装mysql  npm包

地址:https://github.com/felixge/node-mysql

npm install mysql

3、相应API查看及调用:

var mysql      = require('mysql'); var connection = mysql.createConnection({   host     : 'localhost',   user     : 'me',   password : 'secret' });  connection.connect();  connection.query('SELECT 1 + 1 AS solution', function(err, rows, fields) {   if (err) throw err;    console.log('The solution is: ', rows[].solution); });  connection.end();

4、相关注意点及方法

将相应结果进行文件形式保存,使用fs文件系统及path路径模块

var $ = require('underscore'); var fs = require('fs'); var path = require('path');

underscore为数据处理集合,可以简单快捷的进行数据的遍历拼接等处理

npm install underscore
connection.query('select * from  xmmember', function (err, rows) {//account 用户账户表  if (err) throw err;  var tempAccount = $.map(rows, function (c) {   return  {    id: c.ID,    name: c.m_username,    password: c.m_userpass,    surePassword: c.m_userpass,    qq: c.qq   }  });  fs.writeFile(path.join(__dirname, 'account.js'), JSON.stringify(tempAccount), function (err) {   if (err) throw err;   console.log("Export Account Success!");  }); });

将数据查询结果进行JSON格式转换后,导出到具体文件中,方便相应的系统进行导入等管理操作。

相关API方法:

1、配置query格式,进行相应update的操作,代码如下:

connection.config.queryFormat = function (query, values) { if (!values) return query;   return query.replace(/\:(\w+)/g, function (txt, key) { if (values.hasOwnProperty(key)) {       return this.escape(values[key]);     }     return txt;   }.bind(this)); };  connection.query("UPDATE posts SET title = :title", { title: "Hello MySQL" });

2、执行insert操作。如下:

connection.query('INSERT INTO posts SET ?', {title: 'test'}, function(err, result) {   if (err) throw err;    console.log(result.insertId); });

3、删除delete的执行,示例代码以下:

connection.query('DELETE FROM posts WHERE title = "wrong"', function (err, result) { if (err) throw err;    console.log('deleted ' + result.affectedRows + ' rows'); })

4、大量数据查询及操作时候,可以加入相应的容错处理:示例代码如下:

var query = connection.query('SELECT * FROM posts'); query   .on('error', function(err) {     // Handle error, an 'end' event will be emitted after this as well   })   .on('fields', function(fields) {     // the field packets for the rows to follow   })   .on('result', function(row) {     // Pausing the connnection is useful if your processing involves I/O     connection.pause();      processRow(row, function() {       connection.resume();     });   })   .on('end', function() {     // all rows have been received   });

其中,err为具体出现错误时候,所需要进行的错误处理。

fields为具体的执行的结果集合

row为具体结果集每行的处理,可暂停执行及恢复执行。

5、多个查询的同时执行处理,示例代码如下:

先进行如下配置:

var connection = mysql.createConnection({multipleStatements: true});

即可进行多个语句的执行,写法如下:

connection.query('SELECT 1; SELECT 2', function(err, results) {   if (err) throw err;    // `results` is an array with one element for every statement in the query:   console.log(results[]); // [{: }]   console.log(results[]); // [{: }] });

6、结果进行组装处理,代码如下:

var options = {sql: '...', nestTables: true}; connection.query(options, function(err, results) {   /* results will be an array like this now:   [{     table1: {       fieldA: '...',       fieldB: '...',     },     table2: {       fieldA: '...',       fieldB: '...',     },   }, ...]   */ });

或使用如下方式:

var options = {sql: '...', nestTables: '_'}; connection.query(options, function(err, results) {   /* results will be an array like this now:   [{     table1_fieldA: '...',     table1_fieldB: '...',     table2_fieldA: '...',     table2_fieldB: '...',   }, ...]   */ });

7、事物的执行及处理。代码如下:

connection.beginTransaction(function(err) {   if (err) { throw err; }   connection.query('INSERT INTO posts SET title=?', title, function(err, result) {     if (err) {        connection.rollback(function() {         throw err;       });     }      var log = 'Post ' + result.insertId + ' added';      connection.query('INSERT INTO log SET data=?', log, function(err, result) {       if (err) {          connection.rollback(function() {           throw err;         });       }         connection.commit(function(err) {         if (err) {            connection.rollback(function() {             throw err;           });         }         console.log('success!');       });     });   }); });

beginTransaction(), commit() and rollback() 三个方法分别针对SQL事物的开始执行,提交,回滚三个操作。

8、执行超时的捕捉处理,示例代码如下:

connection.query({sql: 'SELECT COUNT(*) AS count FROM big_table', timeout: 60000}, function (err, rows) {   if (err && err.code === 'PROTOCOL_SEQUENCE_TIMEOUT') {     throw new Error('too long to count table rows!');   }    if (err) {     throw err;   }    console.log(rows[0].count + ' rows'); });

9、同时可以对SQL错误代码的处理,示例代码如下:

var connection = require('mysql').createConnection({   port: , // WRONG PORT });  connection.connect(function(err) {   console.log(err.code); // 'ECONNREFUSED'   console.log(err.fatal); // true });  connection.query('SELECT 1', function(err) {   console.log(err.code); // 'ECONNREFUSED'   console.log(err.fatal); // true });

最后,node mySQL提供强大的数据池群处理,以及SSL加密验证功能,在此不做说明,可查看具体API。

本文档参照API简略书写,如有错误,敬请原谅。

nodejs mysql 操作数据库方法一详解的更多相关文章

  1. nodejs mysql 操作数据库方法二

    node.js 开发指南 – Node.js 连接 MySQL 并进行数据库操作 通常在NodeJS开发中我们经常涉及到操作数据库,尤其是 MySQL ,作为应用最为广泛的开源数据库则成为我们的首选, ...

  2. C#操作SQLite方法实例详解

    用 C# 访问 SQLite 入门(1) CC++C#SQLiteFirefox  用 C# 访问 SQLite 入门 (1) SQLite 在 VS C# 环境下的开发,网上已经有很多教程.我也是从 ...

  3. Net Core中数据库事务隔离详解——以Dapper和Mysql为例

    Net Core中数据库事务隔离详解--以Dapper和Mysql为例 事务隔离级别 准备工作 Read uncommitted 读未提交 Read committed 读取提交内容 Repeatab ...

  4. 重新学习MySQL数据库7:详解MyIsam与InnoDB引擎的锁实现

    重新学习Mysql数据库7:详解MyIsam与InnoDB引擎的锁实现 说到锁机制之前,先来看看Mysql的存储引擎,毕竟不同的引擎的锁机制也随着不同. 三类常见引擎: MyIsam :不支持事务,不 ...

  5. MySQL数据类型以及基本使用详解

    MySQL数据类型以及基本使用详解 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.MySQL服务器的主要组件 我们知道MySQL的主要组件主要是由服务端(mysqld)和客户端 ...

  6. 数据库开发-pymysql详解

    数据库开发-pymysql详解 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.Python支持的MySQL驱动 1>.什么是驱动 与MySQL通信就是典型的CS模式.Se ...

  7. CentOS 6.3下Samba服务器的安装与配置方法(图文详解)

    这篇文章主要介绍了CentOS 6.3下Samba服务器的安装与配置方法(图文详解),需要的朋友可以参考下   一.简介  Samba是一个能让Linux系统应用Microsoft网络通讯协议的软件, ...

  8. mysql中event的用法详解

    一.基本概念mysql5.1版本开始引进event概念.event既“时间触发器”,与triggers的事件触发不同,event类似与linux crontab计划任务,用于时间触发.通过单独或调用存 ...

  9. ASP.NET连接Oracle数据库的步骤详解(转)

    ASP.NET连接Oracle数据库的步骤详解   本文我们主要介绍了ASP.NET连接Oracle数据库的步骤及每个步骤需要进行的设置,希望能够对您有所帮助.   在用ASP.NET开发应用程序时, ...

随机推荐

  1. vfptr(1)

    前言 C++中的虚函数的作用主要是实现了多态的机制.关于多态,简而言之就是用父类型别的指针指向其子类的实例,然后通过父类的指针调用实际子类的成员函数.这种技术可以让父类的指针有“多种形态”,这是一种泛 ...

  2. tomcat访问日志分析

    常使用web服务器的朋友大都了解,一般的web server有两部分日志: 一是运行中的日志,它主要记录运行的一些信息,尤其是一些异常错误日志信息 二是访问日志信息,它记录的访问的时间,IP,访问的资 ...

  3. 【BZOJ2799】[Poi2012]Salaries 乱搞

    [BZOJ2799][Poi2012]Salaries Description 给出一棵n个结点的有根树,结点用正整数1~n编号.每个结点有一个1~n的正整数权值,不同结点的权值不相同,并且一个结点的 ...

  4. 20160924-2——mysql常见问题集锦

    一.数据类型相关问题 1.varchar(N)占用多少空间 (1)varchar(N)里的N是字符数,而不是字节数: (2)字符类型(varchar text blob等)空间=字符实际长度+字段长度 ...

  5. ubuntu14.0 hadoop2.4.0 64位基于jdk1.7搭建

    注意:hadoop有两种运行模式,安全模式和非安全模式.安装模式是以指定在健壮的,基于身份验证上运行的,本文无需运行在非安全模式下,可以直接使用root用户. 本文用户是基于root用户来运行的 一. ...

  6. python系列五:Python3列表list

    #!usr/bin/python#-*-coding:gbk-*-#列表list'''可以看到a b c 三个是同一id值,当改变当中任一列表元素的值后,三者会同步改变.但d的元素值不会变,改变d的元 ...

  7. CalendarUtil 日期操作工具类

    版权声明:本文为博主原创文章,未经博主允许不得转载. [java] view plain copy import java.util.Calendar; import java.text.DateFo ...

  8. Android程序运行时权限与文件系统权限的区别

    apk程序是运行在虚拟机上的,对应的是Android独特的权限机制,只有体现到文件系统上时才使用linux的权限设置. (1)Android中的apk必须签名 (2)基于UserID的进程级别的安全机 ...

  9. 安卓3d引擎

    很 多初学Android游戏开发 href="http://edu.gamfe.com/gamedev.html">游戏开发的朋友,往往会显得有些无所适从.他们经常不知道该从 ...

  10. 二值法方法综述及matlab程序

    在某些图像处理当中一个关键步是二值法,二值化一方面能够去除冗余信息,另一方面也会使有效信息丢失.所以有效的二值化算法是后续的处理的基础.比如对于想要最大限度的保留下面图的中文字,以便后续的定位处理. ...