Advertisement

nodejs(五) 连接数据库

阅读量:

参考链接: nodejs连接mysql

1.准备工作

在node.js生态系统中并未提供预装的mySQL模块(MySQL),然而npm作为一个强大的包管理器,在其中提供了mySQL的支持。因此方便地获取并配置自定义的mySQL数据库引擎变得可行。

命令:npm install mysql, 会生成 node_modules 文件夹 , 如图

在操作过程中遇到了提示信息显示缺少package.json 文件。只需运行 npm init -f 命令即可自动生成该文件。

2.直接连接数据库

mysql.createConnection(Object) 方法与 mysql.createPool(Object)的参数

复制代码
  host:       连接数据库所在的主机名. (默认: localhost)

    
     port:       连接端口. (默认: 3306)
    
     localAddress:   用于TCP连接的IP地址. (可选)
    
     socketPath:     链接到unix域的路径。在使用host和port时该参数会被忽略.
    
     user:         MySQL用户的用户名.
    
     password:       MySQL用户的密码.
    
     database:       链接到的数据库名称 (可选).
    
     charset:       连接的字符集. (默认: 'UTF8_GENERAL_CI'.设置该值要使用大写!)
    
     timezone:       储存本地时间的时区. (默认: 'local')
    
     stringifyObjects:   是否序列化对象. See issue #501. (默认: 'false')
    
     insecureAuth:     是否允许旧的身份验证方法连接到数据库实例. (默认: false)
    
     typeCast:       确定是否讲column值转换为本地JavaScript类型列值. (默认: true)
    
     queryFormat:     自定义的查询语句格式化函数.
    
     supportBigNumbers: 数据库处理大数字(长整型和含小数),时应该启用 (默认: false).
    
     bigNumberStrings: 启用 supportBigNumbers和bigNumberStrings 并强制这些数字以字符串的方式返回(默认: false). 
    
     dateStrings: 强制日期类型(TIMESTAMP, DATETIME, DATE)以字符串返回,而不是一javascript Date对象返回. (默认: false)
    
     debug: 是否开启调试. (默认: false)
    
     multipleStatements: 是否允许在一个query中传递多个查询语句. (Default: false)
    
     flags: 链接标志.
    
    
    
    
    代码解释

连接数据库

复制代码
 var mysql  = require('mysql');  //调用MySQL模块

    
 //创建一个connection
    
 var connection = mysql.createConnection({
    
     host: '192.168.3.3',       //主机
    
     user: 'root',               //MySQL认证用户名
    
     password: 'x5',        //MySQL认证用户密码
    
     database: 'dason_yu',
    
     port: '3306'                   //端口号
    
 });
    
 //创建一个connection
    
 connection.connect(function(err){
    
     if(err){
    
     console.log('[query] - :'+err);
    
     return;
    
     }
    
     console.log('[connection connect]  succeed!');
    
 });
    
 //执行sql语句
    
 var userAddSql = 'insert into user (id,name,money) values(?,?,?)';
    
 var param = [3,'ccc',200];
    
 /** * 执行所有类型的 sql 语句
    
  * query(sql,arr[],function)
    
  * @parms: sql:sql语句  arr: 填充站位符的数组,可以缺省
    
  *          function: 回调函数,result: 结果集,对象组成的数组
    
  */
    
 connection.query(userAddSql,param,function(err,rs){
    
     if(err){
    
     console.log('insert err:',err.message);
    
     return;
    
     }
    
     console.log('insert success');
    
 });
    
 //关闭connection
    
 connection.end(function(err){
    
     if(err){
    
     console.log(err.toString());
    
     return;
    
     }
    
     console.log('[connection end] succeed!');
    
 });
    
    
    
    
    代码解释

3.使用连接池连接数据库

将下面代码写到 httpServer.js 文件中

使用在命令行窗口中 node httpServer.js 运行

复制代码
 var mysql = require('mysql'); //用于创建数据库连接

    
  
    
 var pool = mysql.createPool({// 创建数据库连接池
    
     host : '127.0.0.1' ,
    
     user : 'root' ,
    
     password : 'root' ,
    
     database : 'dason',
    
     multipleStatements: true
    
  
    
 });
    
 /** * 获取数据库连接
    
  * @parms: err:异常 connnection:数据库连接对象
    
  * */
    
  
    
 pool.getConnection(function(err,connection){
    
     if(err){
    
     console.log(err);
    
     }
    
     /** * 执行所有类型的 sql 语句
    
      * query(sql,arr[],function)
    
      * @parms: sql:sql语句  arr: 填充站位符的数组,可以缺省
    
      *          function: 回调函数,result: 结果集,对象组成的数组
    
      */
    
     connection.query('SELECT * FROM user',function(err,result){
    
     console.log(result);
    
     connection.release();//将连接放回连接池
    
     });
    
 });
    
    
    
    
    代码解释

结果:

复制代码
 [ RowDataPacket { id: 1, name: 'a', email: 'a@123' },

    
   RowDataPacket { id: 2, name: 'b', email: 'b@123' },
    
   RowDataPacket { id: 4, name: 'd', email: 'd@123' },
    
   RowDataPacket { id: 5, name: 'e', email: 'e@123' },
    
   RowDataPacket { id: 6, name: 'f', email: 'f@123' },
    
   RowDataPacket { id: 3, name: 'c', email: 'c@123' },
    
   RowDataPacket { id: 7, name: 'g', email: 'g@123' } ]
    
    
    
    
    代码解释

4. end() 与 destroy()、release()

end() 会响应一个回调函数,并在 query 执行完毕前调用该函数。当 query 发生错误时,链接将被终止,并将错误信息传递给回调函数。

destroy() 函数马上断开数据库连接,并伴随尚未完成的查询请求,在后续的回调函数也不会被触发。

release() 将连接放回连接池中。

5.package.json

npm install express –save

npm install express –save-dev

上面代码表示单独安装express模块,

–save参数表示将该模块写入dependencies属性,

–save-dev表示将该模块写入devDependencies属性。

全部评论 (0)

还没有任何评论哟~