小编Que*_*ueg的帖子

QSqlField name()方法返回""

我有一个ServicesTableModel继承自的class()QSqlRelationalTableModel.在构造函数中我有:

ServicesTableModel::ServicesTableModel( QWidget* parent, QSqlDatabase db )
: QSqlRelationalTableModel( parent, db )
{ 
    setTable( "servicios" );
    select();
    ...
}
Run Code Online (Sandbox Code Playgroud)

现在,如果我放置线

qDebug() << primaryKey();
Run Code Online (Sandbox Code Playgroud)

点到底我得到了什么

QSqlRecord( 1 ) 
" 0:" QSqlField("ser_id", int, required: no, generated: yes)
Run Code Online (Sandbox Code Playgroud)

这很有道理,但之后

qDebug() << primaryKey().name();
Run Code Online (Sandbox Code Playgroud)

答案是

""

所以我无法达到主键的名称.

该表是sqlite,定义为

CREATE TABLE servicios (ser_id integer primary key, ... )
Run Code Online (Sandbox Code Playgroud)

这很重要,因为我试图将类概括为与表中的行密切相关的对象,并且似乎很自然不必为构造函数提供主键名.

我肯定会做错事,或者我不明白这个name()_方法是QSqlField做什么的.

c++ sql qt

16
推荐指数
1
解决办法
761
查看次数

标签 统计

c++ ×1

qt ×1

sql ×1