azure - 从 JS 中的 Azure Functions 连接到 Azure SQL DB

标签 azure azure-sql-database azure-functions

我正在尝试从用nodeJS编写的azure函数连接到我的Azure SQL DB。我已经在应用程序设置中设置了连接字符串,但它仍然不起作用。我使用 ODBC key 进行连接设置。有人尝试过这个吗?下面是我的函数的示例代码

var Connection = require('tedious').Connection;
var Request = require('tedious').Request;

// Create connection to database
const config = process.env["sqldb_connection"];
var connection = new Connection(config);

// Attempt to connect and execute queries if connection goes through
connection.on('connect', function(err)
   {
     if (err)
       {
          console.log(err)
       }
    else
       {
           queryDatabase()
       }
   }
 );

function queryDatabase()
   { console.log('Reading rows from the Table...');

       // Read all rows from table
     request = new Request(
          "SELECT ORG_ID,ORG_NAME FROM org",
             function(err, rowCount, rows)
                {
                    console.log(rowCount + ' row(s) returned');
                    process.exit();
                }
            );

     request.on('row', function(columns) {
        columns.forEach(function(column) {
            console.log("%s\t%s", column.metadata.colName, column.value);
         });
             });
     connection.execSql(request);
   }

我收到一条错误消息

Exception while executing function: Functions.HttpTriggerJS2. mscorlib: The given key was not present in the dictionary.

最佳答案

  1. D:\home\site\wwwroot 下的 Kudu 远程执行控制台中运行 npm install tedious 命令。

  2. 在 Azure Functions 中,所有代码都应放入 module.exports 函数内。

  3. 您应该使用 context.log() 而不是 console.log()

  4. 您实际上不必在该函数的应用程序设置中设置连接设置字符串。

  5. 当代码完成时,您应该通过调用 context.done() 通知运行时。

以下代码对我有用:

var Connection = require('tedious').Connection;
var Request = require('tedious').Request;

module.exports = function (context, req) {
    context.log('JavaScript HTTP trigger function processed a request.');

    var config = {
        userName: '<userName>',
        password: '<password>',
        server: '<AzureSQLDBName>.database.windows.net',

        // If you're on Windows Azure, you will need this:
    options:
        {
                database: 'your DB',
                  encrypt: true
        }
};

    var connection = new Connection(config);

    connection.on('connect', function(err) {

        if (err) {
            context.log(err);

            context.res = {
                status: 500,
                body: "Unable to establish a connection."
            };
            context.done();

        } else {
            executeStatement();
        }
    });

    function executeStatement() {

        request = new Request("select 42, 'hello world'", function(err, rowCount) {
            if (err) {
                context.log(err);

                context.res = {
                    status: 500,
                    body: "Failed to connect to execute statement."
                };
                context.done();

            } else {
                context.log(rowCount + ' rows');
            }
        });

        request.on('row', function(columns) {
            columns.forEach(function(column) {
                context.log(column.value);
            });

            context.done();
        });

        connection.execSql(request);
    }
};

有关详细信息,请参阅Azure Functions JavaScript developer guide .

关于azure - 从 JS 中的 Azure Functions 连接到 Azure SQL DB,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48773289/

相关文章:

azure - 如何在 Azure 管道运行期间检索 VsTest 测试计划测试用例 ID 并在自动化代码中使用它

azure - 导致 Azure API 管理在收到请求和后端执行之间超时的原因

java - 如何确保Azure Function收到的消息只有一次?

azure - 如何在Azure容器实例中设置cloud_RoleName?

azure - 在自定义环境中将 ASP 5 应用程序发布到 Azure

没有域名的 Azure AD 登录页面

azure - 如何将 Azure Data Lake Storage gen2 文件共享与 Azure Databricks 连接?

azure - Google Analytics 和 Microsoft Azure 集成

sql-server - SQL Server 将日期时间转换为不带 null 的日期

azure - 对于单个查询,一个 Azure SQL 数据库定价层的性能是否比另一个定价层更快?