• <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和Win32SDK的項目,其中涉及到利用QT的方式訪問ACCESS數(shù)據(jù)庫.

            QT利用一種類細于JAVA JDBC的方式呈現(xiàn)給用戶一種極簡單易用的訪問數(shù)據(jù)庫的方式。

            好,下面我直接用代碼說話。以下是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;
                //待續(xù):將新值寫入數(shù)據(jù)庫
            }

            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數(shù)據(jù)庫  回復  更多評論   

            2007-07-31 20:54 by 騰龍居
            東毛子,這又是跨平臺又是原創(chuàng)又是代碼說話,你滿足了吧!@_@
            久久久久久九九99精品| 久久久久亚洲av成人网人人软件 | 久久精品www人人爽人人| 日韩精品久久无码中文字幕| 久久精品无码专区免费东京热 | 久久婷婷五月综合色奶水99啪| 亚洲AV日韩精品久久久久| 99久久免费国产特黄| 亚洲欧美日韩精品久久亚洲区| 久久久精品久久久久影院| 2021少妇久久久久久久久久| 狠狠综合久久综合中文88| 久久天堂AV综合合色蜜桃网| 三级韩国一区久久二区综合| 国产精品对白刺激久久久| 午夜精品久久影院蜜桃| 97久久精品无码一区二区天美| 久久久91人妻无码精品蜜桃HD| 久久综合九色综合网站| 久久国内免费视频| 久久久久久亚洲精品不卡 | 色偷偷久久一区二区三区| 久久www免费人成精品香蕉| 久久久久久无码Av成人影院| 99久久免费国产精品特黄| 青青热久久国产久精品 | 久久久无码精品亚洲日韩京东传媒| 国产精品久久久久…| 久久久老熟女一区二区三区| 中文字幕精品无码久久久久久3D日动漫| 狠狠狠色丁香婷婷综合久久五月 | 精品久久久中文字幕人妻| 久久久WWW成人免费精品| 777米奇久久最新地址| 精品人妻久久久久久888| 日本强好片久久久久久AAA| 久久精品人人做人人爽电影| 久久人人添人人爽添人人片牛牛| 精品久久久久久无码中文字幕| 久久91精品综合国产首页| 亚洲成人精品久久|