node.js学习笔记(25) express与数据库

Express是一个非常好用的web框架,它可以应用与网站、博客、管理系统等等。当我们开发网站等应用的时候,一般都会用数据库来保存数据。这时就需要jdbc这样的驱动来保存连接数据库。

Npmjs.com上提供了丰富的第三方模块,mysql模块就是其中之一,它与mysql数据库同名,是mysql数据库的驱动,用javascript编写的,无需编译。

Hello mysql

先来创建一个mysql的示例,

创建一个nodejs-mysql工程:

mkdir nodejs-mysql
cd nodejs-mysql
npm init
npm install
#安装mysql模块
npm install mysql

准备数据库:

PS. 这是一张图片,这段脚本中可能有什么关键字吧,死活都不能发布,只能用图片了。

代码index.js:

var mysql      = require('mysql');
var connection = mysql.createConnection({
    host     : 'localhost',
    user     : 'root',
    password : 'root',
    database : 'nodejs'
});

connection.connect();

connection.query('select * from user', function(err, rows, fields) {
    if(err) throw err;
    for (var i=0;i <rows.length;i++){
        console.log('username:'+rows[i].username);
    }
});
connection.end();

运行结果:

lee@mypc ~/works/nodejs/study25/nodejs-mysql $ node index.js
username:admin

mysql是一个很好的第三方模块,功能非常强大。然而我习惯了javaEE中的hibernate,习惯了ORM而不是sql语句。所以我浅尝辄止了mysql之后就去寻找下一个第三方模块。

Node-orm是一个node.js的object-relational-mapping框架。它似乎有过好几个名字,orm、node-orm、node-orm2。能支持mysql、mariadb、postgresql、sqlite、mongodb等数据库。

Hello node-orm


nodejs-orm.js:

var orm = require("orm");

orm.connect('mysql://root:root@localhost:3306/nodejs', function(err, db){
    if (err) throw err;
    var User = db.define("user", {
        id          :Number,
        name        :String,
        username    :String,
        password    :String,
        birthday    :Date
    });
    User.find({}, function(err, items) {
        //console.log(items.length);
        for(var i=0;i<items.length;i++){
            console.log('username:'+items[i].username);
        }
    });
});

运行结果:

lee@mypc ~/works/nodejs/study25/nodejs-mysql $ node nodejs-orm.js
username:admin


Express与node-orm

Node-orm可以以中间件的形式跟express结合。

来看一个实例

创建一个express项目:

express express-orm
cd express-orm
npm install
npm install orm
npm install mysql

修改app.js:

...
var orm = require("orm");
...
app.use(orm.express("mysql://root:root@localhost:3306/nodejs", {
    define: function (db, models, next) {
        models.User = db.define("user", {
            id          :Number,
            name        :String,
            username    :String,
            password    :String,
            birthday    :Date
        });
        next();
    }
}));
...

修改routes/users.js:

...
router.get('/', function(req, res, next) {
  req.models.User.find(function(err, users){
      if(err){
          res.send(err);
      }

      res.send(JSON.stringify(users));
  });
});
...

运行并测试expres-orm:

npm start

lee@mypc ~/works/nodejs/study25/express-orm $ curl http://localhost:3000/users
[{"id":1,"name":"lee","username":"admin","password":"admin","birthday":"1988-08-07T23:08:08.000Z"}]


时间: 2024-08-07 01:44:06

node.js学习笔记(25) express与数据库的相关文章

node.js学习笔记(9) 和谐模式

众所周知,ECMAScript 是一种开放的.国际上广为接受的脚本语言规范. 它本身并不是一种脚本语言.正如在 Web 应用程序中执行有用操作的 bean 集合(例如,Netscape 的 AWT)是 Sun 的 JavaBean 规范的一种实现一样,JavaScript 是 ECMAScript 规范的一种实现. 2015年6月17日,ECMA国际发布了EcmaScript2015,即EcmaScript6(以下简称ES6)草案的正式版.ES6是继ES5之后的一次主要改进,语言规范由ES5.1

Node.js 学习笔记之简介、安装及配置

 本文是Node.js学习笔记系列文章的第一篇,主要给大家讲解的是在Windows和Linux上安装Node.js的方法.软件安装版本以0.12.0为例.希望大家能够喜欢.     简单的说 Node.js 就是运行在服务端的 JavaScript. Node.js 是一个基于Chrome JavaScript 运行时建立的一个平台. Node.js是一个事件驱动I/O服务端JavaScript环境,基于Google的V8引擎,V8引擎执行Javascript的速度非常快,性能非常好. 谁适合阅

node.js学习笔记(19) express路由

上一篇笔记中,我们已经使用express-generator创建过express项目.在项目的目录结构中其中一个目录就是routes. 路由是由一个 URI.HTTP 请求(GET.POST等)和若干个回调函数组成. app.METHOD(path, [callback...], callback) - app是express的实例 - METHOD是http的方法,post.get.put.delete...... - path是http请求的URI - callback是当路由匹配时要执行的

node.js学习笔记(21) express日志

创建一个新的express项目,然后运行: mkdir study21 cd study21 express log-morgan cd log-morgan npm install npm start 再用curl,测试http request: curl http://localhost:3000 curl -d '' http://localhost:3000 curl http://localhsot:3000/users curl -d '' http://localhost:3000

node.js学习笔记(18) express

Express是一个简洁而灵活的基于node.js的Web应用框架. 在Express3.6.x之前的版本,Express需要全局安装的,项目构建器模块是合并在 Express项目中的,后来这个构建器被拆分出来,独立成为了一个项目express-generator,现在只需要全局安装express-generator就行了. 全局安装express-genrator.js: sudo npm install -g express-generator 创建express项目: lee@mypc ~

node.js学习笔记(16) child_process(三)

学习过前两篇笔记的源码分析,再来应用child_process的7个方法就不难理解了. By default, pipes for stdin, stdout and stderr are established between the parent Node.js process and the spawned child. 默认情况下,Node.js主进程和子进程间就会建立三个管道:stdin.stdout和stderr,即标准输入流.标准输出流和标准错误流. 如今热播的<芈月传>中有一段

node.js学习笔记(26) node-orm进阶一

上一个笔记中,我们已经认识了node-orm,它可以支持mongodb.mysql.postgres.  redshift. _shared和sqlite. 之所以能支持这么多中数据库,是因为node-orm的lib中有对各种数据库支持的backend脚本,可以看一下orm/lib/Drivers/DML目录下的文件有mongodb.js.mysql.js.postgres.js.redshift.js._shared.js.sqlite.js.这其中的每一个脚本其实都是对各种数据库驱动的封装,

node.js学习笔记(0) 前记

学习笔记原本是从1开始的,然而为了永远"怀念"已经离职的钱童鞋,我决定补上一篇.话说,程序员的数数不都是从0开始的吗. 初识node.js大概是一年前的这个时候,钱童鞋来单位面试,简历上的其中一项技能是node.js.当时我还傻傻的以为又是一个类似jquery的js框架-- 过完年,钱童鞋入职,然后慢慢得熟悉,交流得越来越多,也就慢慢得知node.js的众多优点. google的V8引擎 高速IO 非阻塞 异步回调 单线程 事件驱动 ... 然并卵,吸引我的却是javascript.在

node.js学习笔记(24) 箭头函数

11月下旬,我安装了Node.js-v5.1.0开始学习和使用Node.js. 然而Node.js开发团队在12月发布了v5.1.1,v5.2.0,v5.3.0,16年1月又发布了v5.4.0,v5.4.1,v5.5.0.这速度,是要坐火箭才能赶上呀-- 言归正传,第一次看到"=>"这个符号是在v5.4.0的api文档中.文档中频繁出现这样的代码示例: ()=>{ ... } 通过查Node.js的更新说明得知,这就是箭头函数,是ES6的新特性,Node.js从v5.4.0