您好,欢迎来到爱玩科技网。
搜索
您的当前位置:首页关于mysqlapi中my_bool的取值范围的问题

关于mysqlapi中my_bool的取值范围的问题

来源:爱玩科技网


官方文档中给的描述为:A boolean type, for values that are true (non-zero) or false (zero). 意思是0为false,非0为true。但

my_bool 在mysql中被定义为:char

官方文档中给的描述为:A boolean type, for values that are true (non-zero) or false (zero). 意思是0为false,非0为true。

但是在其接口与具体实现中好像并不是完全按照文档说明的方式进行判断(my_bool值为真为假)。

比如随便找一个接口:

22.9.3.2. mysql_autocommit()

my_bool mysql_autocommit(MYSQL *mysql, my_bool mode)

Description

Sets autocommit mode on if mode is 1, off if mode is 0. (注意这里,,只有mode为1的时候才干事,并不是非0)

Return Values

Zero if successful. Nonzero if an error occurred. (既然想把my_bool当作bool来用,那么为什么返回值又用其返回错误码。)

Errors

None.

我们在项目中碰到过类似的问题,明明 my_bool类型的变量非0,确不被判断为真。汗,与文档描述相悖。

所以比较安全的做法是就把它当作bool来用, 赋值的时候直接用true false.

Copyright © 2019- aiwanbo.com 版权所有 赣ICP备2024042808号-3

违法及侵权请联系:TEL:199 18 7713 E-MAIL:2724546146@qq.com

本站由北京市万商天勤律师事务所王兴未律师提供法律服务