• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            堅鋼不可奪其志 天地莫敢爭其鋒

            無 限 風 光 盡 在 我 心 彌 堅
            posts - 0, comments - 1, trackbacks - 0, articles - 1

            QT中利用ODBC方式訪問ACCESS數據庫

            Posted on 2007-07-31 20:51 Dawn 閱讀(5377) 評論(1)  編輯 收藏 引用 所屬分類: 跨平臺技術相關
             

            最近在做QT和Win32SDK的項目,其中涉及到利用QT的方式訪問ACCESS數據庫.

            QT利用一種類細于JAVA JDBC的方式呈現給用戶一種極簡單易用的訪問數據庫的方式。

            好,下面我直接用代碼說話。以下是3個星期前我寫的一個類模板,專門用于訪問ACCESS。在我的設計中這個類模板的每一個實例化對象專門用于訪問一張表。
            以下是頭文件component.h

            #ifndef COMPONENT_H
            #define COMPONENT_H

            #if defined(_MSC_VER) && (_MSC_VER >= 1020)
            #pragma once
            #endif

            #include <QApplication>
            #include <QString>
            #include <QVector>
            #include <QSqlTableModel>
            #include <QSqlRecord>

            int const PRIMARYKEY_INVALID_VALUE = -1;


            template <typename T>
            class SqlTableObj : public T
            {
            public:
                SqlTableObj() {}
                explicit SqlTableObj(typename T::PrimaryKeyType const &primaryKeyValue);

                typedef SqlTableObj<T> this_type;
                typedef QVector<this_type> CollectionType;

                static CollectionType const collection(QString const &filter = QString(""));
                static void updateState(QString const &filter = QString(""),int *a = NULL );
                static void updateStateEx( QString const &filter = QString(""),int row = 0,int index = 0,int value =0 );
                int getSignals();

            private:
                static void createTableModel(QString const &filter, QSqlTableModel &model);
            };

            template <typename T>
            SqlTableObj<T>::SqlTableObj(typename T::PrimaryKeyType const &primaryKeyValue)
            {
                if (T::primaryKeyInvalidValue() != primaryKeyValue)
             {
               QSqlDatabase qdb = QSqlDatabase::database( T::connectionName(),true );
               QSqlTableModel model( 0, qdb );

                    QString filter = T::primaryKeyName() + QString("=%1");
                    createTableModel(filter.arg(primaryKeyValue), model);
            /*
                    if (1 == model.rowCount())
              {
                        T::assign(model.record(0));
                    }
            */
               T::assign(model.record(0));
                }
            }

            template <typename T> typename SqlTableObj<T>::CollectionType const
            SqlTableObj<T>::collection(QString const &filter/* = QString("")*/)
            {
             QSqlDatabase qdb = QSqlDatabase::database( T::connectionName(),true );
                QSqlTableModel model( 0, qdb );
                createTableModel(filter, model);

                this_type tableObj;
                CollectionType result;

                for (int i = 0; i < model.rowCount(); ++i)
             {
                    tableObj.assign(model.record(i));
                    if (tableObj.valid())
              {
                        result.push_back(tableObj);
                   }
                }

                return result;
            }

            template <typename T>
            void SqlTableObj<T>::updateState( QString const &filter,int *a = NULL )
            {
             QSqlDatabase qdb = QSqlDatabase::database( T::connectionName(),true );
             QSqlTableModel model( 0, qdb );
             createTableModel(filter, model);
            /**/
             for (int i = 0; i < model.rowCount(); i++)
             {
              model.setData( model.index( i, 2 ), a[i] );//a[i]
             }

             model.submitAll();
             //
            }
            template <typename T>
            void SqlTableObj<T>::updateStateEx( QString const &filter = QString(""),
                       int index = 0,int value =0 )
            {
             QSqlDatabase qdb = QSqlDatabase::database( T::connectionName(),true );
             QSqlTableModel model( 0, qdb );
             createTableModel(filter, model);

             model.setData( model.index( index, 2 ), value );

             model.submitAll();
            //// model.record(index).value("state")
            }
            template <typename T>
            void SqlTableObj<T>::updateStateEEx( QString const &filter = QString(""),
                     int row = 0,int index = 0,int value =0 )
            {
             QSqlDatabase qdb = QSqlDatabase::database( T::connectionName(),true );
             QSqlTableModel model( 0, qdb );
             createTableModel(filter, model);

             model.setData( model.index( row, index ), value );

             model.submitAll();
             //// model.record(index).value("state")
            }
            template <typename T>
            int SqlTableObj<T>::getSignals()
            {
             QSqlDatabase qdb = QSqlDatabase::database( T::connectionName(),true );
             QSqlTableModel model( 0, qdb );
             createTableModel("", model);
              
             model.setEditStrategy(QSqlTableModel::OnFieldChange);
             T::assign(model.record(0));

             return 0;
            }
            template <typename T>
            void SqlTableObj<T>::createTableModel(QString const &filter, QSqlTableModel &model)
            {
                model.setTable(T::internalTableName());
                model.setFilter(filter);
                model.select();
            }

            class ComponentTable
            {
            public:
                ComponentTable();

                bool valid() const { return m_id != PRIMARYKEY_INVALID_VALUE; }

                int id() const { return m_id; }

                QString const name() const { return m_name; }
                void setName(QString const &newName);

                QString const filePathName() const { return m_filePathName; }

                int minDistance() const { return m_minDistance; }
                 int maxDistance() const { return m_maxDistance; }

                float direction_X() const { return m_direction_X; }
                 float direction_Y() const { return m_direction_Y; }
                  float direction_Z() const { return m_direction_Z; }

                int fId_1() const { return m_fId_1; }
                 int fId_2() const { return m_fId_2; }
                  int fId_3() const { return m_fId_3; }

                int categoryId() const { return m_categoryId; }

            private:
                friend class SqlTableObj<ComponentTable>;

                typedef int PrimaryKeyType;
                static PrimaryKeyType const primaryKeyInvalidValue() { return PRIMARYKEY_INVALID_VALUE; }
            ////////////////////////////////////////////////////////////////////////////////
                static QString const connectionName()
             {
              return qApp->applicationDirPath() + "/Database/myhpss.mdb";
             }
                static QString const internalTableName()
             {
              return "component";
             }
                static QString const primaryKeyName() { return "ID"; }

                void assign(QSqlRecord const &record);

                int m_id;

                QString m_name;

                QString m_filePathName;

                int m_minDistance;
                int m_maxDistance;

                float m_direction_X;
                float m_direction_Y;
                float m_direction_Z;

                int m_fId_1;
                int m_fId_2;
                int m_fId_3;

                int m_categoryId;
            };

            typedef SqlTableObj<ComponentTable> Component;
            typedef QVector<Component> ComponentArray;

            #endif  //COMPONENT_H

            以下是component.cpp文件
            #include "component.h"

            ComponentTable::ComponentTable()
            {
                m_id = PRIMARYKEY_INVALID_VALUE;

                m_minDistance = -1;
                m_maxDistance = -1;

                m_direction_X = 0.0f;
                m_direction_Y = 0.0f;
                m_direction_Z = 0.0f;

                m_fId_1 = -1;
                m_fId_2 = -1;
                m_fId_3 = -1;

                m_categoryId = -1;
            }

            void ComponentTable::setName(QString const &newName)
            {
                m_name = newName;
                //待續:將新值寫入數據庫
            }

            void ComponentTable::assign(QSqlRecord const &record)
            {
                m_id = record.value("ID").toInt();

                m_name = record.value(QObject::tr("名稱")).toString();

                m_filePathName = record.value("filePathName").toString();

                m_minDistance = record.value("minDistance").toInt();
                m_maxDistance = record.value("maxDistance").toInt();

                m_direction_X = static_cast<float>(record.value("direction_X").toDouble());
                m_direction_Y = static_cast<float>(record.value("direction_Y").toDouble());
                m_direction_Z = static_cast<float>(record.value("direction_Z").toDouble());

                m_fId_1 = record.value("fId_1").toInt();
                m_fId_2 = record.value("fId_2").toInt();
                m_fId_3 = record.value("fId_3").toInt();

                m_categoryId = record.value("categoryID").toInt();
            }
            那個ComponentTable類就是一個能部分說明問題的例子。
            關于完整例程我將隨后補上。

            Feedback

            # re: QT中利用ODBC方式訪問ACCESS數據庫  回復  更多評論   

            2007-07-31 20:54 by 騰龍居
            東毛子,這又是跨平臺又是原創又是代碼說話,你滿足了吧!@_@
            久久99精品国产自在现线小黄鸭 | 久久热这里只有精品在线观看| 久久国产三级无码一区二区| 亚洲国产小视频精品久久久三级| 色天使久久综合网天天| 波多野结衣中文字幕久久| 99久久亚洲综合精品网站| 亚洲AV伊人久久青青草原| 久久久精品国产sm调教网站| 久久无码国产| 久久成人国产精品二三区| 狠狠综合久久综合88亚洲| 99久久国产主播综合精品 | 久久99精品久久久久久秒播| 亚洲av伊人久久综合密臀性色| 99久久国产亚洲高清观看2024| 久久精品亚洲AV久久久无码| 久久久久亚洲AV综合波多野结衣| 久久精品中文闷骚内射| 亚洲另类欧美综合久久图片区| 色综合久久综精品| 无码国产69精品久久久久网站| 久久福利片| 国产精品伊人久久伊人电影| 久久精品人成免费| 久久香蕉超碰97国产精品| 国产69精品久久久久久人妻精品| 久久夜色精品国产www| 久久久WWW免费人成精品| 久久夜色tv网站| 91久久精品视频| 久久本道伊人久久| 国产精品久久久久天天影视| 69久久精品无码一区二区| 久久亚洲精品成人av无码网站| 少妇精品久久久一区二区三区| 婷婷五月深深久久精品| 久久综合精品国产二区无码| 91精品国产9l久久久久| 久久国产精品77777| 国产精品无码久久久久久|