查询没有列'id'的续集表

时间:2017-06-23 19:22:18

标签: javascript mysql node.js sequelize.js backend

我有以下型号

(迁移) transaction.js

    'use strict';
module.exports = {
  up: function(queryInterface, Sequelize) {
    return queryInterface.createTable('transactions', {
      date: {
        type: Sequelize.DATEONLY
      },
      transNo: {
        type: Sequelize.INTEGER,
         allowNull: false,
        autoIncrement: true,
        primaryKey: true,  
    },
      accNo: {
        type: Sequelize.INTEGER
      },
      createdAt: {
        allowNull: false,
        type: Sequelize.DATE
      },
      updatedAt: {
        allowNull: false,
        type: Sequelize.DATE
      }
    });
  },
  down: function(queryInterface, Sequelize) {
    return queryInterface.dropTable('transactions');
  }
};

(模型) transaction.js

  'use strict';
const credit = require('./credit.js'); 
module.exports = function(sequelize, DataTypes) {
  var transaction = sequelize.define('transaction', {
    date: DataTypes.DATEONLY,
    transNo: DataTypes.INTEGER,
    accNo: DataTypes.INTEGER
  }, {
    classMethods: {
      associate: function(models) {
        // associations can be defined here
  transaction.hasOne(models.credit, {foreignKey: 'transNo'});
    }
    }
  });
  return transaction;
};

(模特) credit.js

    module.exports = function(sequelize, DataTypes) {
  var credit = sequelize.define('credit', {
    transNo: DataTypes.INTEGER,
    creNo: DataTypes.INTEGER
  }, {
    classMethods: {
      associate: function(models) {
        // associations can be defined here

      }
    }
  });
  return credit;
};

(迁移) credit.js

` module.exports = {
      up: function(queryInterface, Sequelize) {
        return queryInterface.createTable('credits', {
          transNo: {
            type: Sequelize.INTEGER
          },
          creNo: {
            type: Sequelize.INTEGER,
            autoIncrement: true,
            allowNull: false,
            primaryKey: true
          },
          createdAt: {
            allowNull: false,
            type: Sequelize.DATE
          },
          updatedAt: {
            allowNull: false,
            type: Sequelize.DATE
          }
        });
      },
      down: function(queryInterface, Sequelize) {
        return queryInterface.dropTable('credits');
      }
    };`

它仍然使用id列

进行查询

执行(默认):SELECT transactionidtransactiondatetransactionaccNo,..... ....(等等)。

如何禁止查询id列?

1 个答案:

答案 0 :(得分:-1)

您只需将另一列设置为主键,默认情况下不会生成id列。

 module.exports = function(sequelize, DataTypes) {
  var credit = sequelize.define('credit', {
    transNo: DataTypes.INTEGER,
    {
    creNo: DataTypes.INTEGER,
    primaryKey: true //define a primaryKey

    }
}, {
    classMethods: {
      associate: function(models) {
        // associations can be defined here
      }
    }
  });
  return credit;
};