From bd0f3345a938b35ce6a12f6150373b0955b8dd12 Mon Sep 17 00:00:00 2001 From: Timothy Pearson Date: Sun, 10 Jul 2011 15:24:15 -0500 Subject: Add Qt3 development HEAD version --- doc/html/sql-overview-subclass5-main-cpp.html | 137 ++++++++++++++++++++++++++ 1 file changed, 137 insertions(+) create mode 100644 doc/html/sql-overview-subclass5-main-cpp.html (limited to 'doc/html/sql-overview-subclass5-main-cpp.html') diff --git a/doc/html/sql-overview-subclass5-main-cpp.html b/doc/html/sql-overview-subclass5-main-cpp.html new file mode 100644 index 0000000..cc38935 --- /dev/null +++ b/doc/html/sql-overview-subclass5-main-cpp.html @@ -0,0 +1,137 @@ + + + + + +sql/overview/subclass5/main.cpp Example File + + + + + + + +
+ +Home + | +All Classes + | +Main Classes + | +Annotated + | +Grouped Classes + | +Functions +

sql/overview/subclass5/main.cpp Example File

+ + +
/****************************************************************************
+** $Id: qt/main.cpp   3.3.8   edited Jan 11 14:37 $
+**
+** Copyright (C) 1992-2007 Trolltech ASA.  All rights reserved.
+**
+** This file is part of an example program for Qt.  This example
+** program may be used, distributed and modified without limitation.
+**
+*****************************************************************************/
+
+#include "main.h"
+#include <qdatatable.h>
+
+InvoiceItemCursor::InvoiceItemCursor() :
+    QSqlCursor( "invoiceitem" )
+{
+    QSqlFieldInfo productName( "productname", QVariant::String );
+    append( productName );
+    setCalculated( productName.name(), TRUE );
+
+    QSqlFieldInfo productPrice( "price", QVariant::Double );
+    append( productPrice );
+    setCalculated( productPrice.name(), TRUE );
+
+    QSqlFieldInfo productCost( "cost", QVariant::Double );
+    append( productCost );
+    setCalculated( productCost.name(), TRUE );
+}
+
+
+QVariant InvoiceItemCursor::calculateField( const QString & name )
+{
+
+    if ( name == "productname" ) {
+        QSqlQuery query( "SELECT name FROM prices WHERE id=" +
+                     field( "pricesid" )->value().toString() );
+        if ( query.next() )
+            return query.value( 0 );
+    }
+    else if ( name == "price" ) {
+        QSqlQuery query( "SELECT price FROM prices WHERE id=" +
+                     field( "pricesid" )->value().toString() );
+        if ( query.next() )
+            return query.value( 0 );
+    }
+    else if ( name == "cost" ) {
+        QSqlQuery query( "SELECT price FROM prices WHERE id=" +
+                     field( "pricesid" )->value().toString() );
+        if ( query.next() )
+            return QVariant( query.value( 0 ).toDouble() *
+                             value( "quantity").toDouble() );
+    }
+
+    return QVariant( QString::null );
+}
+
+
+QSqlRecord *InvoiceItemCursor::primeInsert()
+{
+    QSqlRecord *buffer = editBuffer();
+    QSqlQuery query( "SELECT NEXTVAL( 'invoiceitem_seq' )" );
+    if ( query.next() )
+        buffer->setValue( "id", query.value( 0 ) );
+    buffer->setValue( "paiddate", QDate::currentDate() );
+    buffer->setValue( "quantity", 1 );
+
+    return buffer;
+}
+
+
+int main( int argc, char *argv[] )
+{
+    QApplication app( argc, argv );
+
+    if ( createConnections() ) {
+        InvoiceItemCursor invoiceItemCursor;
+
+        QDataTable *invoiceItemTable = new QDataTable( &invoiceItemCursor );
+
+        app.setMainWidget( invoiceItemTable );
+
+        invoiceItemTable->addColumn( "productname", "Product" );
+        invoiceItemTable->addColumn( "price",       "Price" );
+        invoiceItemTable->addColumn( "quantity",    "Quantity" );
+        invoiceItemTable->addColumn( "cost",        "Cost" );
+        invoiceItemTable->addColumn( "paiddate",    "Paid" );
+
+        invoiceItemTable->refresh();
+        invoiceItemTable->show();
+
+        return app.exec();
+    }
+
+    return 1;
+}
+
+


+ +
Copyright © 2007 +TrolltechTrademarks +
Qt 3.3.8
+
+ -- cgit v1.2.1