通过myData db = myData::getMyData(); string sql = "select * from car where cpn='" + cpn + "'"; int row = 0, col = 0; char ** qres; db->getData_exec(sql.c_str(), row, col, qres); string output = ""; if (row > 0) { for (int i = 0; i < row; i++) { for (int j = 0; j < col; j++) { output += qres[icol + j]; output += "\t"; } output += "\r\n"; } this->information_edit->SetWindowText(output.c_str()); system("pause"); return 3; }查询数据有几行,代码示例
时间: 2023-06-13 11:07:03 浏览: 104
该代码示例是使用 C++ 语言访问数据库,执行 SQL 查询语句,并将查询结果输出到窗口中。以下是查询数据有几行的示例代码:
```
int row = 0, col = 0;
char **qres;
string cpn = "ABC123";
string sql = "select * from car where cpn='" + cpn + "'";
myData db = myData::getMyData();
db->getData_exec(sql.c_str(), row, col, qres);
if (row > 0) {
// 查询结果不为空,输出查询结果的行数
cout << "查询结果有 " << row << " 行" << endl;
} else {
// 查询结果为空
cout << "查询结果为空" << endl;
}
```
在上述示例代码中,首先定义了变量 `row` 和 `col`,分别用于保存查询结果的行数和列数。然后定义了变量 `qres`,用于保存查询结果的二维字符数组。接着定义了变量 `cpn` 和 `sql`,分别表示查询条件和 SQL 查询语句。最后创建了一个 `myData` 对象 `db`,并调用其成员函数 `getData_exec()` 执行 SQL 查询语句,将查询结果保存到变量 `qres` 中,并将查询结果的行数和列数保存到变量 `row` 和 `col` 中。如果查询结果不为空,则输出查询结果的行数。
相关问题
myData *db = myData::getMyData(); string sql = "SELECT * FROM car"; int row = 0, col = 0; char ** qres; db->getData_exec(sql.c_str(), row, col, qres); vector<myData> data_list;遍历数据库
的查询结果,将结果存储在一个vector<myData>类型的变量data_list中:
for (int i = 0; i < row; i++) {
myData data;
for (int j = 0; j < col; j++) {
if (qres[i * col + j] != NULL) {
if (j == 0)
data.id = atoi(qres[i * col + j]);
else if (j == 1)
data.name = qres[i * col + j];
else if (j == 2)
data.color = qres[i * col + j];
else if (j == 3)
data.price = atof(qres[i * col + j]);
}
}
data_list.push_back(data);
}
在这段代码中,我们先定义了一个vector<myData>类型的变量data_list,用来存储查询结果。然后用for循环遍历查询结果,每次循环都创建一个myData类型的变量data,用来存储当前这一行的数据。
在内层的for循环中,我们根据列的编号,将查询结果中的值赋给myData对象的对应属性。需要注意的是,我们在赋值之前,先判断查询结果中的值是否为NULL,如果是NULL,则不进行赋值操作。
最后,将myData对象添加到data_list中,完成遍历。
通过myData *db = myData::getMyData(); string sql = "select * from car where cpn='" + cpn + "'"; int row = 0, col = 0; char ** qres; db->getData_exec(sql.c_str(), row, col, qres); string output = ""; if (row > 0) { for (int i = 0; i < row; i++) { for (int j = 0; j < col; j++) { output += qres[i*col + j]; output += "\t"; } output += "\r\n"; } this->information_edit->SetWindowText(output.c_str()); system("pause"); return 3; }查询数据有几行
通过代码可以看出,查询数据的结果保存在 qres 指针数组中,每个元素代表一行数据,而行数则是数组 qres 的长度除以列数 col,因此查询数据的行数为 row = qres长度 / col。可以使用下面的代码获取查询数据的行数:
```cpp
int row = qres长度 / col;
```
阅读全文