• <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>

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

            無 限 風(fēng) 光 盡 在 我 心 彌 堅
            posts - 0, comments - 1, trackbacks - 0, articles - 1
             

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

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

            好,下面我直接用代碼說話。以下是3個星期前我寫的一個類模板,專門用于訪問ACCESS。在我的設(shè)計中這個類模板的每一個實例化對象專門用于訪問一張表。
            以下是頭文件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類就是一個能部分說明問題的例子。
            關(guān)于完整例程我將隨后補上。

            Feedback

            # re: QT中利用ODBC方式訪問ACCESS數(shù)據(jù)庫  回復(fù)  更多評論   

            2007-07-31 20:54 by 騰龍居
            東毛子,這又是跨平臺又是原創(chuàng)又是代碼說話,你滿足了吧!@_@

            只有注冊用戶登錄后才能發(fā)表評論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


            国产福利电影一区二区三区久久久久成人精品综合 | 久久久久久亚洲Av无码精品专口| 久久精品www| 久久99热只有频精品8| 嫩草伊人久久精品少妇AV| 精品久久人人爽天天玩人人妻| 国产亚洲精久久久久久无码AV| 久久综合欧美成人| 精品国产乱码久久久久久郑州公司| 久久夜色精品国产亚洲| 亚洲午夜福利精品久久| 伊人久久大香线蕉无码麻豆| 久久伊人中文无码| 久久亚洲精品无码aⅴ大香| 久久人人爽人人爽人人片av麻烦 | 伊人久久综合热线大杳蕉下载| 丰满少妇人妻久久久久久| 久久婷婷五月综合色奶水99啪| 国产一区二区三区久久| 欧美性大战久久久久久| 亚洲婷婷国产精品电影人久久| 一本久久知道综合久久| 久久狠狠高潮亚洲精品| 精品久久久久久国产三级| 久久久WWW免费人成精品| 一本色综合久久| 国内精品久久久久影院网站| 亚洲人成无码久久电影网站| 亚洲精品乱码久久久久久自慰| 久久99精品久久久久久hb无码 | 欧美色综合久久久久久| 亚洲AV无码久久精品成人| 日韩精品国产自在久久现线拍| 久久久WWW免费人成精品| 久久午夜羞羞影院免费观看| 97久久精品人人澡人人爽| 久久久久久久波多野结衣高潮 | 久久精品综合网| 一本久久久久久久| 伊人久久综合无码成人网| 国产免费福利体检区久久|