【问题标题】:SQL Server connection to node jsSQL Server 连接到节点 js
【发布时间】:2017-01-05 04:37:02
【问题描述】:

我正在尝试在 nodejs 项目和运行 Microsoft SQL Server 2005 的服务器之间建立连接。我正在使用节点模块 mssql,但在尝试创建连接时出现以下错误:

{ [ConnectionError: 无法在 15000 毫秒内连接到 123.123.12.1:1433]
名称:“连接错误”,
消息:'在 15000 毫秒内无法连接到 123.123.12.1:1433',
代码:'ETIMEOUT' }

我的连接是由

var sql = require('mssql');

var dbConfig = {
    server:'123.123.12.1',
    database:'testingDB',
    user:'userName',
    password:'pass',
    port:1433
};

function getEmp() {
    var conn = new sql.Connection(dbConfig);
    var req = new sql.Request(conn);

    conn.connect(function(err) {
        if(err) {
            console.log(err);
            return;
        }
    else {
        console.log('success');
    }
});
}

getEmp();

我不确定我做错了什么,如果有帮助,我正在使用 Cloud 9 IDE。

【问题讨论】:

标签: sql-server node.js database sql-server-2005


【解决方案1】:

将您的var req = new sql.Request(conn) 放入连接中。

// config for your database
var config = {
    user: 'sa',
    password: 'mypassword',
    server: 'localhost', 
    database: 'SchoolDB' 
};

// connect to your database
sql.connect(config, function (err) {

    if (err) console.log(err);

    // create Request object
    var request = new sql.Request();

    // query to the database and get the records
    request.query('select * from Student', function (err, recordset) {

        if (err) console.log(err)

        // send records as a response
        res.send(recordset);

    });
});

【讨论】:

    【解决方案2】:

    它对我有用。首先通过 npm 安装 mssql (npm install --save mssql)

    var sql = require('mssql');
    

    用于本地 sql 服务器

    var sqlConfig = {
      user: 'sa',
      password: 'admin',
      server: 'CBMOBILESHAMIM\\SQLEXPRESS',  
      database: 'databaseName'
    };
    

    用于天蓝色服务器

    var sqlConfig = {
      user: 'adminLogin',
      password: 'admin',
      server: 'severname.database.windows.net',    // don't add tcp & port number
      database: 'databaseName',
      options: {
        encrypt: true
      }
    };
    

    现在连接到服务器

    (async function () {
      try {
        console.log("sql connecting......")
        let pool = await sql.connect(sqlConfig)
        let result = await pool.request()
          .query('select * from Subject')  // subject is my database table name
    
        console.log(result )
    
      } catch (err) {
        console.log(err);
      }
    })()
    

    更多详情请查看mssql

    【讨论】:

    • 非常彻底的答案。谢谢。
    【解决方案3】:
    var webconfig = {
    
    user: 'login',
    
    password: 'sa@123',
    
    server: 'localhost', 
    
    database: 'TestDB',
    
    
    
    options: {
    
        encrypt: false // Use this if you're on Windows Azure 
    
    }
    
      }
    
    
    
    
     var express = require('express');
    
     var sql = require('mssql');
    
     var http = require('http');
    
    
    var connection = new sql.Connection(webconfig, function(err) {
    var request = new sql.Request(connection); 
    request.query('select * from Users', function(err, recordset) {
       if(err)      // ... error checks 
            console.log('Database connection error');
    
    console.dir("User Data: "+recordset);
    });
     });
    
     var app = express();
    
     var port = process.env.PORT || 8000;
    

    或访问这里:https://nodejsbeginersprograms.blogspot.in/2017/02/nodejs-basic-tutorial-with-mssql.html

    【讨论】:

      猜你喜欢
      • 2012-02-08
      • 1970-01-01
      • 2018-03-26
      • 2021-05-19
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2021-04-24
      相关资源
      最近更新 更多