Node.js mysql查询传递给async.waterfall中的下一个函数

时间:2014-01-18 18:02:39

标签: javascript mysql node.js express

我在node.js中使用express有一些代码。我路由一个调用来请求来自mysql数据库的数据,我想要做的是将它传递给另一个函数,将表格形式(表查询)中返回的json重构为层次结构类型json。

我已经单独测试了脚本来重构我的sql查询的输出。但是,我无法将其从查询函数传递到我的新脚本(函数)

我只是没有看到我做错了什么。任何帮助请和谢谢。

exports.get_site_menu = function (req, res) {
    var dbc;
    console.log('In menu setup');
    async.waterfall([
        // get a connection

        function (callback) {
            db.db(callback);
        }

        ,
        querylookup, modifyjson
    ], completed);

    function querylookup(dbclient, res) {
        dbc = dbclient;
        dbc.query("SELECT categories, " +
            "subcategories, " +
            "pid, " +
            "title, " +
            "description " +
            "FROM MENU_SELECT_ACTIVE_VIEW " +
            "where company_id = ? and site_id = ?", [req.query.companyid, req.query.siteid], res);
    }

    function modifyjson(err, res) {

        categories = [];

        console.log('results ' + res);

        res.forEach(function (entry) {
            var cindex = categories.map(function (category) {
                return category.name;
            }).indexOf(entry.categories);

            console.log(cindex);
            if (cindex < 0) {
                // Not found in categories array
                cindex = categories.push({
                    name: entry.categories,
                    subcategories: []
                }) - 1; // -1 to fix the index
            }
            // Lets search the subcategory
            var category = categories[cindex];

            var sindex = category.subcategories.map(
                function (subcategory) {
                    return subcategory.name;
                }
            ).indexOf(entry.subcategories);

            if (sindex < 0) {
                // Not Found
                sindex = category.subcategories.push({
                    name: entry.subcategories,
                    items: []
                }) - 1;
            }
            // Subcategory exists. Just push
            category.subcategories[sindex].items.push({
                pid: entry.pid,
                description: entry.description,
                title: entry.title
            });
        });

        menu = {
            menu: {
                categories: categories
            }
        };
        console.log('menu ' + menu);
    }


    function completed(err, menu, fields) {
        if (dbc) dbc.end();
        if (err) {
            callback(err);
        } else {
            console.log(menu);
            res.contentType('json');
            res.send(JSON.stringify(menu));
        }
    }
};

1 个答案:

答案 0 :(得分:1)

您需要将每个结果传递给自己的回调以传递下一个函数。我重构了你的代码,如;

exports.get_site_menu = function (req, res) {
    var dbc;
    console.log('In menu setup');
    async.waterfall([
        // get a connection

        function (callback) {
            db.db(callback, some_result);
        },
        function querylookup(dbclient, res, callback) {
            dbc = dbclient;
            dbc.query("SELECT categories, " +
                "subcategories, " +
                "pid, " +
                "title, " +
                "description " +
                "FROM MENU_SELECT_ACTIVE_VIEW " +
                "where company_id = ? and site_id = ?", [req.query.companyid, req.query.siteid], res);
                callback(null, result_from_queryLookup);
        },
        function modifyjson(err, res, callback) {

            categories = [];

            console.log('results ' + res);

            res.forEach(function (entry) {
                var cindex = categories.map(function (category) {
                    return category.name;
                }).indexOf(entry.categories);

                console.log(cindex);
                if (cindex < 0) {
                    // Not found in categories array
                    cindex = categories.push({
                        name: entry.categories,
                        subcategories: []
                    }) - 1; // -1 to fix the index
                }
                // Lets search the subcategory
                var category = categories[cindex];

                var sindex = category.subcategories.map(
                    function (subcategory) {
                        return subcategory.name;
                    }
                ).indexOf(entry.subcategories);

                if (sindex < 0) {
                    // Not Found
                    sindex = category.subcategories.push({
                        name: entry.subcategories,
                        items: []
                    }) - 1;
                }
                // Subcategory exists. Just push
                category.subcategories[sindex].items.push({
                    pid: entry.pid,
                    description: entry.description,
                    title: entry.title
                });
            });

            menu = {
                menu: {
                    categories: categories
                }
            };
            console.log('menu ' + menu);
            callback(null, menu, fields);
        }
    ], function completed(err, menu, fields) {
        if (dbc) dbc.end();
        if (err) {
            callback(err);
        } else {
            console.log(menu);
            res.contentType('json');
            res.send(JSON.stringify(menu));
        }
    });
};

特别是要小心回调部分。