sql-server - 如何让 Sails.js 查询现有数据库?

标签 sql-server node.js jdbc sails.js waterline

已经为另一个项目设置了一个开发数据库。我正在尝试创建一个 sails.js 服务器来连接到该数据库并充当 RESTful API。我也在使用SQL Workbench使用下面的配置文件连接到数据库并验证我的查询语句。在该工具上,我可以发送类似 select top 10 * from advisor 的查询并获取我期望的响应数据。

SQL Workbench Connection Profile

我在 sails.js 中的连接配置似乎没问题,因为我能够启动服务器。我已经得到了简单的静态操作,例如 hi: function (req, res) { return res.send("Hi there!"); } 。但是,我不知道该怎么做才能从 sails 提供的数据库中获取响应。我的目标(此时)是 http://localhost:1337/advisor返回 select top 10 * from advisor 的结果的 JSON .

我最初尝试使用新生成的模型。然后,我尝试向模型文件添加属性。然后,我尝试将自己的代码添加到 Controller 中。在每种情况下,浏览器都从未收到响应。最后我测试了/advisor/list运行我自己的代码,但看起来并没有执行过 query() 回调。如果这是第一个问题,我已经运行了 npm install sails-sqlserver我已经仔细检查了我的主机、数据库、用户名和密码是否与 Workbench 中使用的相同。

connections.js

sqlserver: {
  adapter: 'sails-sqlserver',
  user: 'myusername',
  password: 'mypassword',
  host: 'mysubdomain.mydomain.net:1433',
  database: 'frontofficedev'
}

models.js

module.exports.models = {
  connection: 'sqlserver',
  migrate: 'safe'
};

api\models\Advisor.js

module.exports = {
  attributes: {
    advcode: 'string',
    advname: 'string',
    'adv-default': 'boolean',
    "user-id": 'string',
    "pc-code": 'string',
    "adv-tag": 'string',
    "is-group": 'boolean',
    "trade-grouping": 'string',
    AdvisorId: 'int',
    orgcode: 'string',
    BranchId: 'int',
    OrdPrnBranchId: 'int',
    zdec1: 'float',
    zdec2: 'float',
    zchar1: 'string',
    zchar2: 'string',
    zchar3: 'string',
    zchar4: 'string',
    AdvStatus: 'string'
  }
};

api\ Controller

module.exports = {
  hi: function (req, res) {
    return res.send("Hi there!");
  },
  list: function (req, res) {
    var myQuery = "select TOP 10 * from advisor";

    sails.log.debug("Query :", myQuery);

    console.log(Advisor);

    Advisor.query(myQuery, function (err, advisors){
      console.log(advisors);
      console.log(err);
      if(err || !advisors.rows.length){
        return res.json({"status": 0, "error": err});
      }
      else{
        return res.json(advisors);
      }
    });
  }
};

关于我做错了什么有什么想法吗? JDBC 是否会导致问题?提前致谢。

最佳答案

我假设您已经运行:npm install sails-sqlserver --save

您必须指定您将在模型中使用的连接和表,模型中的变量应与您的数据库变量匹配,如下所示:

api\models\Advisor.js

    module.exports = {
    schema: true,
    connection: 'sqlserver',
    tableName: 'yourTableName',
    attributes: {
    advcode:{
       type: 'string',
       primaryKey: true //if this is a primary key
    }, 
    advname:{
       type: 'string'
    },
    'adv-default':{
       type: 'boolean'
  }
};

在您的 Controller 中,您可以像这样使用 Sails ORM 水线:

api\ Controller

module.exports = {
  list: function (req, res) {
    Advisor.query('SELECT * FROM advisor', function(err, results) {
      if (err) {
        res.send(400);
      } else {
        res.send(results);
      }
    });
  }
};

其中 Advisor 是模型。

有关模型和 ORM 水线的更多具体信息,我建议您阅读 sails 文档:http://sailsjs.org/documentation/reference/waterline-orm/models

关于sql-server - 如何让 Sails.js 查询现有数据库?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32264207/

相关文章:

c# - 查找每个键具有最大值的行

node.js - typeORM 未发现数据库架构更改 - 无法生成迁移。要创建新的空迁移,请使用 "typeorm migration:create"命令

javascript - 似乎无法推送和返回一组对象 sequelize 查询

javascript - 当 docker-compose 退出时运行可执行文件

r - Kerberos 身份验证的 Hive JDBC 连接问题 - R

java - 池空。无法在 10 秒内获取连接

c# - 如何在使用池时测量 SqlConnection 上的登录时间?

C# SQL父子表选择查询帮助

sql-server - SQL 服务器 : splitting a row into several rows based off it's start and end date

java - 使用java程序执行Mysql查询包含汉字