>데이터 베이스 >MySQL 튜토리얼 >关于mysql api中my_bool的取值范围的问题

关于mysql api中my_bool的取值范围的问题

WBOY
WBOY원래의
2016-06-07 17:20:021094검색

官方文档中给的描述为: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.

linux

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.