$testMessage = "TESTMESSAGE";
$db = new sqlite3('messages.sq3');
$db->exec('CREATE TABLE messages(id INTEGER PRIMARY KEY, message CHAR(255));');
$db->exec("INSERT INTO messages (message) VALUES ('$testMessage');");
$results = $db->query('SELECT * FROM messages ORDER BY id DESC LIMIT 5');
while ($row = $results->fetchArray()) {
print_r($row);
}
产生的print_r:
Array ( [0] => 1 [id] => 1 [1] => TESTMESSAGE [message] => TESTMESSAGE )
为什么要重复这些数据?这只是数组的显示方式还是真的有TESTMESSAGE字符串的两个副本?检查sqlite文件,我只看到一个实际存储在其中的文件.我正在尝试通过JSON序列化输出,并且此重复一直在进行序列化.
解决方法:
默认设置是将具有数字键和字符串键的数据合并到同一数组中.
您需要使用$results-> fetchArray(sqlite3_NUM)或$results-> fetchArray(sqlite3_ASSOC)分别获取数字键和字符串键.默认值为sqlite3_BOTH,我一直讨厌它.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。