1. 国内使用npm安装某些插件的时候,偶尔会有网络问题,可以使用cnpm:(后续所有使用 npm 无法正常安装的,都改成 cnpm 试试)

  a. 首先使用 npm 安装 cnpm:npm install -g cnpm --registry=https://registry.npm.taobao.org

  b. 使用 cnpm -v 查看版本号:

    

2. 使用ORM插件sequelize,及自动生成表对象插件sequelize-auto。

  官方地址:

  https://github.com/sequelize/sequelize

  https://github.com/sequelize/sequelize-auto

  a. 使用 npm 安装 sequelize : npm install sequelize

  b. 然后全局安装 mysql 及 sequelize-auto :npm install -g mysql sequelize-auto

  c. 按文档使用命令行生成 model 文件:sequelize-auto -o "./xxxx/model/" -d database_name -h 192.168.1.1 -u sa -p 3306 -x 123456 -e mysql

    其他参数查阅 https://www.npmjs.com/package/sequelize-auto

  d. 检查文件夹 “./xxxx/model/” 下是否已经生成model对应文件,文件名与数据库表名相同。

3. 修改 sequelize-auto 的 model 模板,为 model 增加构造函数。

  a. 找到 sequelize-auto 的 model 模板:C:\Users\XXX\AppData\Roaming\npm\node_modules\sequelize-auto\lib\index.js

  b. 目前的版本是20161201提交的,大概在300行的位置,修改代码如下:

    

      //由于增加后续代码,注释掉移除逗号相关代码 by MikeJia 20161212
//text[table] = text[table].trim()
//text[table] = text[table].substring(0, text[table].length - 1);
//********************************************************
//region add by MikeJia 20161212
var params="";
var setAttr="";
_.each(fields, function(field, x){
//自动编号列不列在构造函数中
var isSerialKey = self.tables[table][field].foreignKey && _.isFunction(self.dialect.isSerialKey) && self.dialect.isSerialKey(self.tables[table][field].foreignKey)
if(!isSerialKey){
params += field + ",";
setAttr += "'" + field + "':" + field + ",";
}
}); params = params.substring(0, params.length - 1);
setAttr = "{" + setAttr.substring(0, setAttr.length - 1) + "}";
text[table] += spaces + spaces + "classMethods: {\n";
text[table] += spaces + spaces + spaces + "getInstance:function(" + params + ") {\n";
text[table] += spaces + spaces + spaces + spaces + "return " + setAttr + ";\n";
text[table] += spaces + spaces + spaces + "}\n";
text[table] += spaces + spaces + "}";
//regionend add by MikeJia 20161212
//********************************************************

4. 使用 sequelize-auto 模板生成 model 后,mysql 数据库无法保存时间到毫秒。

  a. 查看 model 会发现,datetime 类型的字段被设置为 ‘DataTypes.DATE’,该类型无法保存时间到毫秒。有两个解决方案:

    I. 修改 sequelize 源码

    II. 修改 sequelize-auto 模板

    第二种简单一点。

  b. 打开3.中提到的 sequelize-auto 模板文件。目前的版本是20161201提交的,大约238行左右,将原有代码注释掉,修改为 DateType.STRING 。代码如下:    

            else if (_attr.match(/^(date)/)) {
val = 'DataTypes.STRING'
//val = 'DataTypes.DATE';
}
else if (_attr.match(/^(time)/)) {
val = 'DataTypes.STRING'
//val = 'DataTypes.TIME';
}

5. 使用ab进行测试

  a. 直接使用npm安装:npm install ab 。参考 https://www.npmjs.com/package/ab

  b. 如果报错 “gyp ERR! stack Error: Can't find Python executable "python", you can set the PYTHON env variable.”,需要安装python,官网下载(https://www.python.org/downloads/)。

node开发的更多相关文章

  1. node开发 npm install -g express-generator@4

    Node forever : 1,forever start --uid test start app.js 2,forever start --uid test start -a app.js 3, ...

  2. [转] 使用NVM快速搭建NODE开发环境

    export NVM_NODEJS_ORG_MIRROR=https://npm.taobao.org/mirrors/node 本文主要介绍最近自己碰到的几个坑以及搜索到的相应解决方案: 如何快速搭 ...

  3. node开发环境配置

    node开发环境配置 用处 NodeJS——后台 JavaScript-前台 后台其他语言 1.PHP 2.Java 3.Pythonnode优势 1.性能高 nodejs php 86 1s 1分半 ...

  4. 手把手教你用Vue2+webpack+node开发一个H5 app

    手把手教你用Vue2+webpack+node开发一个H5 app ​前一篇vue2 + webpack + node 开发一个小demo说到了用vue的一些基本用法,这一篇就讲一个复杂一点的更完整的 ...

  5. 前端开发 Vue -1windows环境搭建Vue Node开发环境

    解决几个疑问: 想学习下vue.js,我理解的它是一个前端的框架,主要作用是对数据的处理,和juqery类似,所以不太理解为什么要在nodejs中npm install vue呢?在html文件中引入 ...

  6. 如何用node开发自己的cli工具

    如何用node开发自己的cli工具 灵感 写这个工具的灵感以及场景源于youtube的一次闲聊 github 地址 blog首发 使用场景 原本我们写博客展示shell,例如:安装运转docker,一 ...

  7. node开发指南

    Node.js 能做什么 正如 JavaScript 为客户端而生,Node.js 为网络而生.Node.js 能做的远不止开发一个网站那么简单,使用 Node.js,你可以轻松地开发: 具有复杂逻辑 ...

  8. 用node开发repl应用

    前言 每次看到一些库npm -g install xx然后,执行xx就可以跑起来,这不就是一个shell工具了吗,那么我不就可以不用学习shell语法,直接用js写命令行脚本了吗! 什么是REPL应用 ...

  9. 全栈工程师带你开发 ,node开发人脸识别门禁系统

    效果图:       知识点: 人脸识别SKD部署,  webRTC视频流处理,URL构建blob对象,Canvas映射截图,ajax数据交互,Node图像处理,跨域与413处理,base64解码,p ...

  10. Vue笔记:使用node开发vue入门实例

    安装NPM 首先在命令终端输入 npm -v 检测是否安装 npm.如果没有,按照下面教程进行安装. 下载地址: nodejs中文网 到官网下载自己系统对应的版本,这里我们下载Windows系统的64 ...

随机推荐

  1. 通过dataGridView控件中的checkBox控件对数据库进行批量删除

    string id_s = ""; ; i < dataGridView1.Rows.Count; i++) //遍历所有行 { if (dataGridView1.Rows ...

  2. Android菜鸟成长记16 -- JSON的解析

    JSON的定义  一种轻量级的数据交换格式,具有良好的可读和便于快速编写的特性.业内主流技术为其提供了完整的解决方案(有点类似于正则表达式 ,获得了当今大部分语言的支持),从而可以在不同平台间进行数据 ...

  3. Android菜鸟成长记7 -- Android的五大布局

    Android五大布局,相信android的都了解过,今天我根据自己的学习整理一下五大布局,主要介绍的是线性布局(LiearLayout),因为,其他的布局使用率不是很高. Android的五大布局 ...

  4. 写css时要注意数字的浮动方向

    写css时要注意数字的浮动方向  当数字位数增加时他的方向才是正确的 text-align:right;padding-right:29px;

  5. 转发(forward)和重定向(sendRedirect)

    一. RequestDispatche 是一个Web资源的包装器,可以用来把当前的Request传递给该资源,或者把新的资源包括到当前的相应中.详细来说:RequestDispatch对象从客户端获取 ...

  6. .NET MVC TempData、ViewData、ViewBag

    说明: 原文作者贤新 原文地址:http://www.cnblogs.com/chenxinblogs/p/4852813.html ViewData和ViewBag主要用于将数据从控制器中传递到视图 ...

  7. 用纯css改变下拉列表select框的默认样式

    http://ourjs.com/detail/551b9b0529c8d81960000007 在这篇文章里,我将介绍如何不依赖JavaScript用纯css来改变下拉列表框的样式. 问题的提出 事 ...

  8. NGUI 多场景情况下 管理多个界面

    简单的说就是在一个AllUI场景中,所有场景所需要的界面都挂在一个Empty GameObject下,然后这个Empty GameObject在代码中DontDestroyOnLoad,但是回到这个A ...

  9. Gradle笔记系列(一)

    1.Gradle概述 Gradle是一个基于Apache Ant和Apache Maven概念的项目自动化构建工具.它使用一种基于Groovy的特定领域语言(DSL)来声明项目设置,抛弃了基于XML的 ...

  10. android opengl es代码功能

    /* * Copyright (C) 2009 The Android Open Source Project * * Licensed under the Apache License, Versi ...