为什么Node.js中的Sequelize.js总是从MySQL位字段返回true?
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了为什么Node.js中的Sequelize.js总是从MySQL位字段返回true?,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2134字,纯文字阅读大概需要4分钟。
内容图文
![为什么Node.js中的Sequelize.js总是从MySQL位字段返回true?](/upload/InfoBanner/zyjiaocheng/894/301ff2cdbd6344e28587a2a04f17e43f.jpg)
我有一个Node.Js Express应用程序,我正在使用Sequelize.js OR / M来查询MySQL 5.6数据库.我有一个名为homes的表,其中包含几个位字段(其中一个称为isrental,我在模型中定义为布尔值.当查询数据库时,即使我在记录中存储了0,这些字段也总是返回true这是一个快速的代码示例:
var Sequelize = require('sequelize-mysql').sequelize;
var orm = new Sequelize('mysql://procHOAPro:password@NewMasterBedRm/HOAPro'), {
dialect: 'mysql',
language: 'en'
});
var Home = orm.define('homes', {
homeid : Sequelize.INTEGER,
state : Sequelize.STRING,
county : Sequelize.STRING,
city : Sequelize.STRING,
zip : DataTypes.STRING,
isrental : {type: Sequelize.BOOLEAN, allowNull: true, defaultValue: false},
isbuilderowned : {type: Sequelize.BOOLEAN, allowNull: true, defaultValue: false},
mailingaddress : Sequelize.STRING
});
Home.all().success(function(homes) {
console.log(homes[0].isrental);
console.log(homes[1].isrental);
});
表定义:
CREATE TABLE’homes'(
‘homeid’int(11)NOT NULL AUTO_INCREMENT,
‘state’varchar(2)NOT NULL,
‘county’varchar(100)NOT NULL,
‘city’varchar(100)NOT NULL,
‘zip’varchar(5)NOT NULL,
‘section’varchar(50)NOT NULL,
‘township’int(11)NOT NULL,
‘townshipdir’varchar(1)NOT NULL,
‘range’int(11)NOT NULL,
‘rangedir’varchar(1)NOT NULL,
‘block’int(11)NOT NULL,
‘lot’int(11)NOT NULL,
‘physicaladdress’varchar(255)NOT NULL,
‘isrental’位(1)NOT NULL DEFAULT b’0’,
‘isbuilderowned’int(1)NOT NULL DEFAULT’0’,
‘mailingaddress’varchar(255)DEFAULT NULL,
PRIMARY KEY(‘homeid’),
UNIQUE KEY’homeid_UNIQUE'(‘homeid’)
)ENGINE = InnoDB AUTO_INCREMENT = 12 DEFAULT CHARSET = utf8;
输出:
Executing: SELECT * FROM
homes
;
true <–this is bs…it’s a 0 in the db
true <–this is bs…it’s a 0 in the db
作为一个fyi,我也使用了node-orm OR / M,我得到了完全相同的行为.
解决方法:
你的表定义似乎是正确的,错误是sequelize / sequelize和node-mysql一起播放的方式. Node-mysql将位字段作为Buffer实例返回,但是sequelize需要一个tinyint. tinyint可以通过双重否定它来转换为boolean(!!值),而double否定缓冲区总是返回true.
修复似乎很简单,只需检查值是否为缓冲区,然后再尝试将其转换为boolean.你能不能在sequelize github上为它创建一个问题,然后我希望能尽快解决这个问题
内容总结
以上是互联网集市为您收集整理的为什么Node.js中的Sequelize.js总是从MySQL位字段返回true?全部内容,希望文章能够帮你解决为什么Node.js中的Sequelize.js总是从MySQL位字段返回true?所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。