我有一个类似的问题,但我的解决方案是这样的: 可能你需要改变一些东西,但它的工作原理。
self.model = QSqlRelationalTableModel()
self.model.setTable("FK The table Name")
self.model.setRelation(index, QSqlRelation("Pkey table", "The id field", "The value field you want"))
self.model.select()
在设置创造一个映射关系,如果你想
self.mapper = QDataWidgetMapper()
self.mapper.setModel(self.model)
relModel = self.model.relationModel(index) #the same from the SetRelation
self.YourCombBox.setModel(relModel)
self.TourCombBox.setModelColumn(relModel.fieldIndex("The value field you want"))
self.mapper.addMapping(self.YourCombBox, int)
self.mapper.toFirst()
,并保存你只是去和
_insertRecord = QSqlRecord()
_insertRecord.append(QSqlField(int, QVarinat.WhatEverTypeItIs))
quer = QSqlQueryModel()
quer.setQuery("SELECT id FROM TheTable where Name = '%s'" %(YourComboxCurrentText()))
_insertRecord.setValue(int, quer.record(0).value("id"))
self.model.insertRowIntoTable(_insertRecord)
self.model.select()