我有一个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做什么的.
primaryKey.name()返回索引的名称。
在 SQL 中,可以命名索引,这与用于键的字段名称无关。
一个索引可以作用于多个字段。每个字段名称都可以通过key.fieldName(i), with来检索0<i<key.count()