跳到主要内容

DB_SelectNextRow

描述

该函数用于在通过DB_ExecuteQuery分配的结果集中移动到下一行。

参数名说明
DBResult:dbresult查询结果句柄(由DB_ExecuteQuery返回)

返回值

  • true​ - 结果集句柄有效且未到达最后一行
  • false​ - 结果集句柄无效或已遍历所有行

示例

// 示例模块

// ...

Examples_ListNames(DB:dbConnectionHandle)
{
// 执行数据库查询
new DBResult:db_result_set = DB_ExecuteQuery(dbConnectionHandle, "SELECT `name` FROM `examples`");

if (db_result_set)
{
// 预分配结果存储空间
new result[256];

// 遍历结果集
do
{
// 通过字段名称获取数据
DB_GetFieldStringByName(db_result_set, "name", result, sizeof(result));
}
while (DB_SelectNextRow(db_result_set)); // 跳转至下一行

// 释放结果集
DB_FreeResultSet(db_result_set);
}
}
// 主游戏模式文件

// ...

#include <examples>

static DB:gDBConnectionHandle;

// ...

public OnGameModeInit()
{
// ...

// 建立数据库连接
gDBConnectionHandle = DB_Open("example.db");

if (gDBConnectionHandle)
{
print("成功连接数据库 \"example.db\"");
Examples_ListNames(gDBConnectionHandle);
}
else
{
print("无法连接数据库 \"example.db\"");
}

return 1;
}

public OnGameModeExit()
{
// 关闭数据库连接
if (DB_Close(gDBConnectionHandle))
{
gDBConnectionHandle = DB:0; // 重置句柄
}
return 1;
}

注意事项

危险

使用非法的结果集句柄将导致服务器崩溃!请始终通过DB_ExecuteQuery获取有效的查询结果!

相关函数