直接上代码
var resu;
var db = require("./dbs.js");
var http=require("http");
var server=http.createServer(function(req,res){
if(req.url!=="/favicon.ico"){
resu = db.searchDb();
res.writeHead(200,{"Content-Type":"text/plain","Access-Control-Allow-Origin":"*"});
res.write(resu);
}
res.end();
});
server.listen(1338,"localhost",function(){
console.log("开始监听...");
});
这个是数据库查询的文件
exports.searchDb =function(){
var Mysql = require('node-mysql-promise');
var mysql = Mysql.createConnection({
host: 'dm191867.my3w.com',
user: 'dm191867',
password: '123',
// database:'dm191867_db',
});
//SELECT * FROM table;
mysql.table('SalesInfo').field('OrderNO,OrderDate,CustomID,Quantity,Money,OrderStatus').select().then(function (data) {
return data;
console.log(data);
}).catch(function (e) {
console.log(e);
});
}
报错信息
_http_outgoing.js:439
throw new TypeError('first argument must be a string or Buffer');
^
TypeError: first argument must be a string or Buffer
at ServerResponse.OutgoingMessage.write (_http_outgoing.js:439:11)
at Server.<anonymous> (c:\Users\lenovo\WebstormProjects\bootstrap\myserver.js:8:13)
at emitTwo (events.js:87:13)
at Server.emit (events.js:172:7)
at HTTPParser.parserOnIncoming [as onIncoming](_http_server.js:528:12)
at HTTPParser.parserOnHeadersComplete (_http_common.js:88:23)
刚刚接触nodejs 被搞得头大 请大神帮忙!
按照大神的方法改好了,但是遇到了新的问题。我现在mysql.query('XXXXXX')中的sql句是固定的。我想动态生成不同的sql语句,就在searchDb的参数里加了个sqldata。
代码如下:
exports.searchDb =function (sqldata,resultCallback){
var Mysql = require('node-mysql-promise');
var mysql = Mysql.createConnection({
host: 'qdm19.my3w.com',
user: 'qdm19',
password: '123E',
database:'qdm19_db',
});
//SELECT XX FROM table;
mysql.query('SELECT DISTINCT %s,%s,%s,%s,%s,%s FROM %s WHERE %s',sqldata).then(function (data)
{
console.log(data);
resultCallback(null,data);
}).catch(function (e) {
console.log(e);
resultCallback(e);
});
}
其中sqldata是个数组
var sqldata=
[
'OrderNO',
'DATE_FORMAT( OrderDate , "%Y-%m-%d")OrderDate',
'c.CustomName',
'(select count(Quantity) from SalesInfo where OrderNo=s.OrderNO)Quantity',
'(select sum(Money) from SalesInfo where OrderNo=s.OrderNO)Money',
'OrderStatus',
'SalesInfo as s left join Customer as c on s.CustomID=c.CustomNo',
'1=1'
]
换成这种形式以后 第一次查询是没有问题的 再点一次查询就会报错说sql句有问题。。
虽然我没用过,但是你应该把promise返回吧?
return mysql.table('SalesInfo').xxxxx
然后
db.searchDb().then(function(data) {
})
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。