当前位置: 首页>NodeJS>Nodejs学习笔记(四)与MySQL交互(felixge/node

Nodejs学习笔记(四)与MySQL交互(felixge/node

时间:2015-06-29 23:44 来源:网络整理 作者:KKWL 点击:
Nodejs学习笔记(四)与MySQL交互(felixge/node-mysql) 作者:porschev来源:IT165收集发布日期:2014-04-14 20:51:29 目录 简介和安装 测试MySQL 认识一下Connection Options MYSQL CURD 插入 更新 查询 删除

 

 

Nodejs学习笔记(四)与MySQL交互(felixge/node-mysql)

作者:porschev  来源:IT165收集  发布日期:2014-04-14 20:51:29

 

 

  • 目录 简介和安装 测试MySQL 认识一下Connection Options MYSQL CURD 插入 更新 查询 删除 Nodejs 调用带out参数的存储过程,并得到out参数返回值 结束数据库连接两种方法和区别 连接池Pooling connections 创建 其它连接池配置选项 释放 使用示例 断线重连 其它... 简介和安装

      Node.js与MySQL交互操作有很多库,具体可以在 https://www.npmjs.org/search?q=mysql  查看。

      我选择了felixge/node-mysql,用的人比较多,先随大溜看看它的使用,暂时没有太过纠结于各库之间的执行性能问题,对其它库有研究的筒子也可以分享一下性能要求较高时的选择^_^! 

      

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

           https://www.npmjs.org/package/mysql

    This is a node.js driver for mysql. It is written in JavaScript, does not require compiling, and is 100% MIT licensed

      用纯JavaScript实现。MIT 100%!

      安装

    npm install mysql

      

    \

      

     

      注意:安装前先把目录cd到node.exe所在目录下,这样执行安装命令时,会找到目录下node_modules,并安装在此目录下,否则使用mysql时,你会出现 Error: Cannot find module 'mysql' 

    测试MySQL

      MySQL版本:5.5

      在官方示例的基础下修改一下并测试:

      

    \

     

     

    var mysql = require('mysql'); //调用MySQL模块 //创建一个connection var connection = mysql.createConnection({ host : '192.168.0.200', //主机 user : 'root', //MySQL认证用户名 password : 'abcd', //MySQL认证用户密码 port: '3306', //端口号 }); //创建一个connection connection.connect(function(err){ if(err){ console.log('[query] - :'+err); return; } console.log('[connection connect] succeed!'); }); //执行SQL语句 connection.query('SELECT 1 + 1 AS solution', function(err, rows, fields) { if (err) { console.log('[query] - :'+err); return; } console.log('The solution is: ', rows[0].solution); }); //关闭connection connection.end(function(err){ if(err){ return; } console.log('[connection end] succeed!'); }); 测试示例源码

      成功执行!

    认识一下Connection Options

      要想创建一个数据库连接,先就要认识清楚Options

      host:主机地址 (默认:localhost)

      user:用户名

      password:密码

      port:端口号 (默认:3306)

      database:数据库名

      charset:连接字符集(默认:'UTF8_GENERAL_CI',注意字符集的字母都要大写)

      localAddress:此IP用于TCP连接(可选)

      socketPath:连接到unix域路径,当使用 host 和 port 时会被忽略

      timezone:时区(默认:'local')

      connectTimeout:连接超时(默认:不限制;单位:毫秒)

      stringifyObjects:是否序列化对象(默认:'false' ;与安全相关https://github.com/felixge/node-mysql/issues/501)

      typeCast:是否将列值转化为本地JavaScript类型值 (默认:true)

      queryFormat:自定义query语句格式化方法 https://github.com/felixge/node-mysql#custom-format

      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:用于修改连接标志,更多详情:https://github.com/felixge/node-mysql#connection-flags

      ssl:使用ssl参数(与crypto.createCredenitals参数格式一至)或一个包含ssl配置文件名称的字符串,目前只捆绑Amazon RDS的配置文件

      其它:

      可以使用URL形式的加接字符串,不多介绍了,不太喜欢那种格式,觉得可读性差,也易出错,想了解的可以去主页上看。

    MYSQL CURD

       首先创建一个测试数据库nodesample,在数据库中建一个userinfo表

    CREATE DATABASE IF NOT EXISTS nodesample CHARACTER SET UTF8; USE nodesample; SET FOREIGN_KEY_CHECKS=0; DROP TABLE IF EXISTS `userinfo`; CREATE TABLE `userinfo` ( `Id` int(11) NOT NULL AUTO_INCREMENT COMMENT '主键', `UserName` varchar(64) NOT NULL COMMENT '用户名', `UserPass` varchar(64) NOT NULL COMMENT '用户密码', PRIMARY KEY (`Id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='用户信息表';

      1.向UserInfo表中插入一条数据

顶一下
(0)
0%
踩一下
(0)
0%
------分隔线----------------------------