📄 editbook.ui.h
字号:
void EditBookForm::init(){ QSqlQuery query( "SELECT surname, id FROM author ORDER BY surname;" ); while ( query.next() ) { ComboBoxAuthor->insertItem( query.value( 0 ).toString() ); int id = query.value( 1 ).toInt(); mapAuthor( query.value( 0 ).toString(), id, TRUE ); }}void EditBookForm::beforeUpdateBook( QSqlRecord * buffer ){ int id; mapAuthor( ComboBoxAuthor->currentText(), id, FALSE ); buffer->setValue( "authorid", id );}void EditBookForm::mapAuthor( const QString & name, int & id, bool populate ){ if ( populate ) authorMap[ name ] = id; else id = authorMap[ name ];}void EditBookForm::primeInsertBook( QSqlRecord * buffer ){ QSqlQuery q; q.exec( "UPDATE sequence SET sequence = sequence + 1 WHERE tablename='book';" ); q.exec( "SELECT sequence FROM sequence WHERE tablename='book';" ); if ( q.next() ) { buffer->setValue( "id", q.value( 0 ) ); } }void EditBookForm::primeUpdateBook( QSqlRecord * buffer ){ // Who is this book's author? QSqlQuery query( "SELECT surname FROM author WHERE id=" + buffer->value( "authorid" ).toString() + ";" ); QString author = ""; if ( query.next() ) author = query.value( 0 ).toString(); // Set the ComboBox to the right author for ( int i = 0; i < ComboBoxAuthor->count(); i++ ) { if ( ComboBoxAuthor->text( i ) == author ) { ComboBoxAuthor->setCurrentItem( i ) ; break; } }}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -