首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >QSqlField name()方法返回"“

QSqlField name()方法返回"“
EN

Stack Overflow用户
提问于 2012-04-22 18:30:29
回答 1查看 786关注 0票数 16

我有一个继承自QSqlRelationalTableModel的类(ServicesTableModel)。在构造函数中,我有:

代码语言:javascript
复制
ServicesTableModel::ServicesTableModel( QWidget* parent, QSqlDatabase db )
: QSqlRelationalTableModel( parent, db )
{ 
    setTable( "servicios" );
    select();
    ...
}

现在,如果我把这条线

代码语言:javascript
复制
qDebug() << primaryKey();

我得到的点在哪里?

代码语言:javascript
复制
QSqlRecord( 1 ) 
" 0:" QSqlField("ser_id", int, required: no, generated: yes)

这很有道理,但之后

代码语言:javascript
复制
qDebug() << primaryKey().name();

答案是

"“

所以我找不到主键的名字。

该表是sqlite,使用定义

代码语言:javascript
复制
CREATE TABLE servicios (ser_id integer primary key, ... )

这很重要,因为我正在尝试为与表中的行密切相关的对象泛化该类,而且似乎不需要向构造函数提供主键名称是很自然的。

我肯定做错了什么,或者我不明白QSqlField中的name()_方法是做什么的。

EN

回答 1

Stack Overflow用户

发布于 2015-04-09 03:23:03

primaryKey.name()返回索引的名称。

在SQL中,索引可以命名,这独立于用于键的字段的名称。

一个索引可以在多个字段上工作。每个字段名称都可以使用key.fieldName(i)0<i<key.count()进行检索

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/10267193

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档