• <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 閱讀(5378) 評論(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九九国产免费看小说| 国产精品久久久久久福利69堂| 国产精品成人99久久久久91gav | 久久精品无码av| 少妇熟女久久综合网色欲| 亚洲成色WWW久久网站| 99久久国产主播综合精品| 亚洲国产高清精品线久久| 色8激情欧美成人久久综合电| 日韩精品久久久久久久电影蜜臀 | 久久人人爽人人爽人人爽| 久久亚洲精品视频| 久久WWW免费人成一看片| 亚洲国产成人久久精品动漫| 欧美伊人久久大香线蕉综合| 亚洲一区二区三区日本久久九| 亚洲精品高清一二区久久| 久久精品一区二区国产| 亚洲精品午夜国产VA久久成人| 精品多毛少妇人妻AV免费久久| 久久亚洲AV成人无码电影| 久久久久久免费视频| 国产精品久久久天天影视香蕉| 久久Av无码精品人妻系列| 区久久AAA片69亚洲| 欧美色综合久久久久久| 精品久久久久久无码中文野结衣| 国产亚洲精品自在久久| 少妇久久久久久被弄高潮| 久久无码中文字幕东京热| 性做久久久久久久久| 一级做a爰片久久毛片毛片| 久久夜色撩人精品国产小说| 国内精品久久久久久久涩爱| 99国内精品久久久久久久| 91精品国产综合久久婷婷| 久久ZYZ资源站无码中文动漫| 久久久久免费看成人影片| 色综合久久综合中文综合网| 日本欧美久久久久免费播放网| 人妻精品久久久久中文字幕69|