开发者社区> 问答> 正文

MySQL C API mysql_fetch_row()的问题

假设表account有以下字段:
user_name : varchar(16)
password : varchar(32)
在 password 存放的是 md5 散列值(占用 32 字节)
执行完 select user_name, password from account 之后
row = mysql_fetch_row(res);
请问 row[0] 和 row[1] 是否都是以空字符 '0' 结束的?
我在某台机器上测试的时候,发现如果某一记录的 password 字段的长度达到了 32,返回的数据貌似不是空字符结束的,而我将 password 的类型改为 varchar(33) 之后便正常了。

注:我使用的是 MySQL 提供的 C API,不是 PHP
求各位大神帮助

展开
收起
落地花开啦 2016-02-08 16:46:58 3359 0
1 条回答
写回答
取消 提交回答
  • 数据库对应表字符串的长度不够导致的

    2019-07-17 18:39:48
    赞同 展开评论 打赏
问答排行榜
最热
最新

相关电子书

更多
搭建电商项目架构连接MySQL 立即下载
搭建4层电商项目架构,实战连接MySQL 立即下载
PolarDB MySQL引擎重磅功能及产品能力盛大发布 立即下载

相关镜像