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


            欧美精品一区二区久久| 成人a毛片久久免费播放| 精品一二三区久久aaa片| 色综合久久久久久久久五月| 亚洲欧美日韩中文久久| 国产欧美一区二区久久| 久久精品国产一区| 亚洲va久久久久| 久久国产乱子精品免费女| 久久伊人影视| 青青青国产精品国产精品久久久久 | 伊人久久精品影院| 99久久人妻无码精品系列蜜桃| 国产精品无码久久四虎| 亚洲国产精品18久久久久久| 久久99久久无码毛片一区二区| 久久久久国产精品熟女影院| 久久久久九国产精品| 精品久久一区二区| 久久这里只有精品18| 人人狠狠综合久久亚洲| 色综合久久天天综合| 久久久久高潮毛片免费全部播放| 亚洲国产日韩欧美综合久久| 久久精品国产亚洲网站| 久久九九精品99国产精品| 精品伊人久久大线蕉色首页| 久久免费观看视频| 久久人搡人人玩人妻精品首页 | 久久久亚洲精品蜜桃臀| 久久精品成人国产午夜| 久久丫精品国产亚洲av不卡| 久久精品国产亚洲AV影院| 中文成人久久久久影院免费观看| 大美女久久久久久j久久| 久久精品一区二区国产| 久久精品国产亚洲精品2020| 国内精品久久久久影院一蜜桃| 无码人妻久久久一区二区三区| 大香伊人久久精品一区二区| 亚洲а∨天堂久久精品9966|