SOCI 行集<row>奇怪错误
SOCI rowset<row> weird error
我最近为我的项目安装了SOCI库,因为它需要使用SQLite数据库。我试图获取行集,但我得到了一个奇怪的错误:
"c:mingwincludesociexchange-traits.h:35:5: error: incomplete type 'soci::details::exchange_traits<soci::row>' used in nested name specifier".
我不知道我的代码出了什么问题。。。造成该错误的行是:
soci::rowset<> results = (sql.prepare << "SELECT * from games where user_name='" << user.getName() << "'");
顺便说一下,我使用的是最新版本的SOCI。代码的较宽部分:
soci::session& sql = conn.getSession();
soci::rowset<> results = (sql.prepare << "SELECT * from games where user_name='" << user.getName() << "'");
for(soci::rowset<>::const_iterator it = results.begin(); it != results.end(); ++it)...
您必须指定soci::rowset
的类型,因为它是模板化的类型。例如,如果select
是一个整数列,则使用soci::rowset<int>
作为results
的类型。您的示例是一个特殊情况,因为您还不知道类型,但对于这个soci已经定义了soci::row
类型,所以您可以使用soci::rowset<soci::row> results
此外,您永远不应该通过串联用户输入字符串来构建查询,因此sql.prepare << "SELECT * from games where user_name='" << user.getName() << "'"
使用CCD_ 8。
否则,您很容易受到所谓的SQL注入攻击
相关文章:
- 警告处理为错误这里有什么问题
- "error: no matching function for call to"构造函数错误
- boost::进程间消息队列引发错误
- C++,OpenCV,尝试显示图像时"OpenCV(4.3.0) Error: Assertion failed (size.width>0 && size.height>0)"此错误
- 有关插入适配器的错误。[错误]请求从 'back_insert_iterator<vector<>>' 类型转换为非标量类型
- QT在错误的班级中寻找空位
- vector.resize()中的分配错误
- 代码在main()中运行,但在函数中出现错误
- 释放错误后堆使用
- (C++)分析树以计算返回错误值的简单算术表达式
- Project Euler问题4的错误解决方案
- 我的字符计数代码计算错误.为什么
- 从"int*"强制转换为"unsigned int"会丢失精度错误
- 尝试导入pybind-opencv模块时出现libgtk错误
- CMake项目Boost库错误:Boost/config/compiler/gcc.hpp:165:10:致命错误:cs
- 在某些循环内使用vector.push_back时出现分段错误
- 错误,包括&lt; ctype&gt;在原子上使用C 11
- 错误c++visual studio c2227左侧'->;Init';必须指向类/结构/联合/泛型类型
- opencv 2.4.7在iOS错误背景_segm.hpp #include&lt; list&gt;未找到
- 链接器(MinGW的ld v2.23.2)错误,格式:-L<SOMEDIR>-l<lib1-l<l