Mysql
 sql >> Datenbank >  >> RDS >> Mysql

Abfragen einer MySQL-Datenbank von einer NodeJS-AWS-Lambda-Funktion

Das Problem war, dass ich meinen context.succeed in meine Rückrufe einfügen musste. Vielen Dank an sqlbot, da sein Gerede über Rückrufe mich dazu veranlasste, zu untersuchen, wo Dinge ihre Ausführung tatsächlich beenden.

Wenn also bei der Verwendung von AWS Lambda der "Kontext" endet, bevor Ihre Rückrufe aufgerufen werden, erhalten Sie Ihre Rückrufe nicht. Obwohl ich alle meine Callbacks so platziert hatte:connect -> query -> end, wird der erste Callback der Kette von connect nie aufgerufen, weil "context.succeed" direkt danach aufgerufen wurde, was die Ausführung beendete.

Hier ist mein Code ab sofort (erhält jetzt eine richtige Abfrage):

var mysql = require('mysql');
var connection = mysql.createConnection({
    ...
});

exports.handler = (event, context) => {
    try {

        if (event.session.new) {
            // New Session
            console.log("NEW SESSION");
        }


        switch (event.request.type) {

            case "LaunchRequest":
                // Launch Request
                console.log(`LAUNCH REQUEST`);
                context.succeed(
                    generateResponse({},
                        buildSpeechletResponse("Welcome to an Alexa Skill, this is running on a deployed lamda function", true)
                    )
                );
                break;

            case "IntentRequest":
                // Intent Request
                console.log(`Intent Request`);
                console.log('Then run MySQL code:');
                connection.connect(function(err) {
                    console.log('Inside connection.connect() callback');
                    if (!err) {
                        console.log("Database is connected ... ");
                        connection.query("INSERT INTO Users (user_id) VALUES ('TESTNAME')",
                            function(err, result) {
                                console.log("Inside connection.query() callback")
                                if (!err) {
                                    console.log("Query Successful! Ending Connection.");
                                    connection.end();
                                } else {
                                    console.log("Query error!");
                                }
                            });
                    } else {
                        console.log("Error connecting database ..." + err.message);
                    }
                    context.succeed(
                        generateResponse({},
                            buildSpeechletResponse("Welcome to the incredible intelligent MySQLable Alexa!", true)
                        )
                    );
                });

                break;

            case "SessionEndedRequest":
                // Session Ended Request
                console.log(`SESSION ENDED REQUEST`);
                break;

            default:
                context.fail(`INVALID REQUEST TYPE: ${event.request.type}`);

        }

    } catch (error) {
        context.fail(`Exceptiodn: ${error}`)
    }

};

//Helpers
buildSpeechletResponse = (outputText, shouldEndSession) => {

    return {
        outputSpeech: {
            type: "PlainText",
            text: outputText
        },
        shouldEndSession: shouldEndSession
    };
};

generateResponse = (sessionAttributes, speechletResponse) => {
    return {
        version: "1.0",
        sessionAttributes: sessionAttributes,
        response: speechletResponse
    };
};