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

               
  • 目录

    简介和安装 测试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

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

      \ 

    \
    01. var mysql  = require('mysql');  //调用MySQL模块
    02.  
    03. //创建一个connection
    04. var connection = mysql.createConnection({    
    05. host     : '192.168.0.200',       //主机
    06. user     : 'root',               //MySQL认证用户名
    07. pass<a href="http://www.it165.net/edu/ebg/" target="_blank" class="keylink">word</a> :'abcd',        //MySQL认证用户密码
    08. port: '3306',                   //端口号
    09. });
    10. //创建一个connection
    11. connection.connect(function(err){
    12. if(err){       
    13. console.log('[query] - :'+err);
    14. return;
    15. }
    16. console.log('[connection connect]  succeed!');
    17. }); 
    18. //执行SQL语句
    19. connection.query('SELECT 1 + 1 AS solution', function(err, rows, fields) {
    20. if (err) {
    21. console.log('[query] - :'+err);
    22. return;
    23. }
    24. console.log('The solution is: ', rows[0].solution); 
    25. }); 
    26. //关闭connection
    27. connection.end(function(err){
    28. if(err){       
    29. return;
    30. }
    31. console.log('[connection end] succeed!');
    32. });
    测试示例源码

      成功执行!

    认识一下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表

    01. CREATE DATABASE IF NOT EXISTS nodesample CHARACTER SET UTF8;
    02.  
    03. USE nodesample;
    04.  
    05. SET FOREIGN_KEY_CHECKS=0;
    06.  
    07. DROP TABLE IF EXISTS `userinfo`;
    08. CREATE TABLE `userinfo` (
    09. `Id` int(11) NOT NULL AUTO_INCREMENT COMMENT '主键',
    10. `UserName` varchar(64) NOT NULL COMMENT '用户名',
    11. `UserPass` varchar(64) NOT NULL COMMENT '用户密码',
    12. PRIMARY KEY (`Id`)
    13.

猜你喜欢

转载自blog.csdn.net/qq_43741569/article/details/84316963