首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >knex.js管表示

knex.js管表示
EN

Stack Overflow用户
提问于 2014-10-15 07:07:04
回答 1查看 1.7K关注 0票数 5

我在knex.jsexpress中有一个问题,代码如下:

代码语言:javascript
复制
userRouter.get('/:userId', function (req, res) {
  DB('users').where({
    id: req.params.userId
  }).first('name').pipe(res);
});

正如knex.js文档所写:有一个用于knex.js查询的流接口。

但我无法将结果传递到express(node http api)响应。

以上代码不起作用。

有一个"TypeError":

TypeError:第一个参数必须是字符串或缓冲区

出什么问题了?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-12-30 13:15:26

创建一个流,并首先将其输送到JSONStream,最后将其输送到响应对象。

代码语言:javascript
复制
var knex = require('knex')({
  client: 'mysql',
  connection: {
    host     : '...',
    user     : '...',
    password : '...',
    database : '...'
  }
});
var JSONStream = require('JSONStream');
var express = require('express');
var app = express();

app.get('/', function (req, res) {
    var sql = knex.select('*').from('table').limit(3);
    res.set('Content-Type', 'application/json');
    sql.stream().pipe(JSONStream.stringify()).pipe(res);
});

var server = app.listen(3000, function () {
  var host = server.address().address;
  var port = server.address().port;

  console.log('Example app listening at http://%s:%s', host, port);
});
票数 6
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/26376454

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档