亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? qsqltablemodel.cpp

?? QT 開發環境里面一個很重要的文件
?? CPP
?? 第 1 頁 / 共 3 頁
字號:
/*!    Returns the primary key for the current table, or an empty    QSqlIndex if the table is not set or has no primary key.    \sa setTable(), setPrimaryKey(), QSqlDatabase::primaryIndex()*/QSqlIndex QSqlTableModel::primaryKey() const{    Q_D(const QSqlTableModel);    return d->primaryIndex;}/*!    Protected method that allows subclasses to set the primary key to    \a key.    Normally, the primary index is set automatically whenever you    call setTable().    \sa primaryKey(), QSqlDatabase::primaryIndex()*/void QSqlTableModel::setPrimaryKey(const QSqlIndex &key){    Q_D(QSqlTableModel);    d->primaryIndex = key;}/*!    Returns a pointer to the used QSqlDatabase or 0 if no database was set.*/QSqlDatabase QSqlTableModel::database() const{    Q_D(const QSqlTableModel);     return d->db;}/*!    Sorts the data by \a column with the sort order \a order.    This will immediately select data, use setSort()    to set a sort order without populating the model with data.    \sa setSort(), select(), orderByClause()*/void QSqlTableModel::sort(int column, Qt::SortOrder order){    setSort(column, order);    select();}/*!    Sets the sort oder for \a column to \a order. This does not    affect the current data, to refresh the data using the new    sort order, call select().    \sa select(), orderByClause()*/void QSqlTableModel::setSort(int column, Qt::SortOrder order){    Q_D(QSqlTableModel);    d->sortColumn = column;    d->sortOrder = order;}/*!    Returns an SQL \c{ORDER BY} clause based on the currently set    sort order.    \sa setSort(), selectStatement()*/QString QSqlTableModel::orderByClause() const{    Q_D(const QSqlTableModel);    QString s;    QSqlField f = d->rec.field(d->sortColumn);    if (!f.isValid())        return s;    s.append(QLatin1String("ORDER BY ")).append(d->tableName).append(QLatin1Char('.')).append(f.name());    s += d->sortOrder == Qt::AscendingOrder ? QLatin1String(" ASC") : QLatin1String(" DESC");    return s;}/*!    Returns the index of the field \a fieldName.*/int QSqlTableModel::fieldIndex(const QString &fieldName) const{    Q_D(const QSqlTableModel);    return d->rec.indexOf(fieldName);}/*!    Returns the SQL \c SELECT statement used internally to populate    the model. The statement includes the filter and the \c{ORDER BY}    clause.    \sa filter(), orderByClause()*/QString QSqlTableModel::selectStatement() const{    Q_D(const QSqlTableModel);    QString query;    if (d->tableName.isEmpty()) {        d->error = QSqlError(QLatin1String("No table name given"), QString(),                             QSqlError::StatementError);        return query;    }    if (d->rec.isEmpty()) {        d->error = QSqlError(QLatin1String("Unable to find table ") + d->tableName, QString(),                             QSqlError::StatementError);        return query;    }    query = d->db.driver()->sqlStatement(QSqlDriver::SelectStatement, d->tableName,                                          d->rec, false);    if (query.isEmpty()) {        d->error = QSqlError(QLatin1String("Unable to select fields from table ") + d->tableName,                             QString(), QSqlError::StatementError);        return query;    }    if (!d->filter.isEmpty())        query.append(QLatin1String(" WHERE ")).append(d->filter);    QString orderBy(orderByClause());    if (!orderBy.isEmpty())        query.append(QLatin1Char(' ')).append(orderBy);    return query;}/*!    Removes \a count columns from the \a parent model, starting at    index \a column.    Returns if the columns were successfully removed; otherwise    returns false.    \sa removeRows()*/bool QSqlTableModel::removeColumns(int column, int count, const QModelIndex &parent){    Q_D(QSqlTableModel);    if (parent.isValid() || column < 0 || column + count > d->rec.count())        return false;    for (int i = 0; i < count; ++i)        d->rec.remove(column);    if (d->query.isActive())        return select();    return true;}/*!    Removes \a count rows starting at \a row. Since this model    does not support hierarchical structures, \a parent must be    an invalid model index.    Emits the beforeDelete() signal before a row is deleted.    Returns true if all rows could be removed; otherwise returns    false. Detailed error information can be retrieved using    lastError().    \sa removeColumns(), insertRows()*/bool QSqlTableModel::removeRows(int row, int count, const QModelIndex &parent){    Q_D(QSqlTableModel);    if (parent.isValid() || row < 0 || count <= 0)        return false;    int i;    switch (d->strategy) {    case OnFieldChange:    case OnRowChange:        for (i = 0; i < count; ++i) {            if (row + i == d->insertIndex)                d->revertInsertedRow();            else if (!deleteRowFromTable(row + i))                return false;        }        select();        break;    case OnManualSubmit:        for (i = 0; i < count; ++i) {            int idx = row + i;            if (idx >= rowCount())                return false;            if (d->cache.value(idx).op == QSqlTableModelPrivate::Insert)                revertRow(idx);            else                d->cache[idx].op = QSqlTableModelPrivate::Delete;        }        break;    }    return true;}/*!    Inserts \a count empty rows at position \a row. Note that \a    parent must be invalid, since this model does not support    parent-child relations.    Only one row at a time can be inserted when using the    OnFieldChange or OnRowChange update strategies.    The primeInsert() signal will be emitted for each new row.    Connect to it if you want to initialize the new row with default    values.    Returns false if the parameters are out of bounds; otherwise    returns true.    \sa primeInsert(), insertRecord()*/bool QSqlTableModel::insertRows(int row, int count, const QModelIndex &parent){    Q_D(QSqlTableModel);    if (row < 0 || count <= 0 || row > rowCount() || parent.isValid())        return false;    switch (d->strategy) {    case OnFieldChange:    case OnRowChange:        if (count != 1)            return false;        beginInsertRows(parent, row, row);        d->insertIndex = row;        // ### apply dangling changes...        d->clearEditBuffer();        emit primeInsert(row, d->editBuffer);        break;    case OnManualSubmit:        beginInsertRows(parent, row, row + count - 1);        if (!d->cache.isEmpty()) {            QMap<int, QSqlTableModelPrivate::ModifiedRow>::Iterator it = d->cache.end();            while (it != d->cache.begin() && (--it).key() >= row) {                int oldKey = it.key();                const QSqlTableModelPrivate::ModifiedRow oldValue = it.value();                d->cache.erase(it);                it = d->cache.insert(oldKey + count, oldValue);            }        }        for (int i = 0; i < count; ++i) {            d->cache[row + i] = QSqlTableModelPrivate::ModifiedRow(QSqlTableModelPrivate::Insert,                                                                   d->rec);            emit primeInsert(row + i, d->cache[row + i].rec);        }        break;    }    endInsertRows();    return true;}/*!    Inserts the \a record after \a row. If \a row is negative, the    record will be appended to the end. Calls insertRows() and    setRecord() internally.    Returns true if the row could be inserted, otherwise false.    \sa insertRows(), removeRows()*/bool QSqlTableModel::insertRecord(int row, const QSqlRecord &record){    Q_D(QSqlTableModel);    if (row < 0)        row = rowCount();    if (!insertRow(row, QModelIndex()))        return false;    if (!setRecord(row, record))        return false;    if (d->strategy == OnFieldChange || d->strategy == OnRowChange)        return submit();    return true;}/*! \reimp*/int QSqlTableModel::rowCount(const QModelIndex &parent) const{    Q_D(const QSqlTableModel);    if (parent.isValid())        return 0;    int rc = QSqlQueryModel::rowCount();    if (d->strategy == OnManualSubmit) {        for (QSqlTableModelPrivate::CacheMap::ConstIterator it = d->cache.constBegin();             it != d->cache.constEnd(); ++it) {             if (it.value().op == QSqlTableModelPrivate::Insert)                 ++rc;        }    } else if (d->insertIndex >= 0) {        ++rc;    }    return rc;}/*!    Returns the index of the value in the database result set for the    given \a item in the model.    The return value is identical to \a item if no columns or rows    have been inserted, removed, or moved around.    Returns an invalid model index if \a item is out of bounds or if    \a item does not point to a value in the result set.    \sa QSqlQueryModel::indexInQuery()*/QModelIndex QSqlTableModel::indexInQuery(const QModelIndex &item) const{    Q_D(const QSqlTableModel);    const QModelIndex it = QSqlQueryModel::indexInQuery(item);    if (d->strategy == OnManualSubmit) {        int rowOffset = 0;        QSqlTableModelPrivate::CacheMap::ConstIterator i = d->cache.constBegin();        while (i != d->cache.constEnd() && i.key() <= it.row()) {            if (i.value().op == QSqlTableModelPrivate::Insert)                ++rowOffset;            ++i;        }        return createIndex(it.row() - rowOffset, it.column(), it.internalPointer());    } else {        if (d->insertIndex >= 0 && it.row() >= d->insertIndex)            return createIndex(it.row() - 1, it.column(), it.internalPointer());    }    return it;}/*!    Returns the currently set filter.    \sa setFilter(), select()*/QString QSqlTableModel::filter() const{    Q_D(const QSqlTableModel);    return d->filter;}/*!    Sets the current filter to \a filter.    The filter is a SQL \c WHERE clause without the keyword \c WHERE    (for example, \c{name='Josephine')}.    If the model is already populated with data from a database,    the model re-selects it with the new filter. Otherwise, the filter    will be applied the next time select() is called.    \sa filter(), select(), selectStatement(), orderByClause()*/void QSqlTableModel::setFilter(const QString &filter){    Q_D(QSqlTableModel);    d->filter = filter;    if (d->query.isActive())        select();}/*! \reimp*/void QSqlTableModel::clear(){    Q_D(QSqlTableModel);    d->clear();    QSqlQueryModel::clear();}/*! \reimp*/Qt::ItemFlags QSqlTableModel::flags(const QModelIndex &index) const{    Q_D(const QSqlTableModel);    if (index.internalPointer() || index.column() < 0 || index.column() >= d->rec.count()        || index.row() < 0)        return 0;    if (d->rec.field(index.column()).isReadOnly())        return Qt::ItemIsSelectable | Qt::ItemIsEnabled;    return Qt::ItemIsSelectable | Qt::ItemIsEnabled | Qt::ItemIsEditable;}/*!    Sets the values at the specified \a row to the values of \a    record. Returns true if all the values could be set; otherwise    returns false.    \sa record()*/bool QSqlTableModel::setRecord(int row, const QSqlRecord &record){    Q_D(QSqlTableModel);    if (row >= rowCount())        return false;    bool isOk = true;    switch (d->strategy) {    case OnFieldChange:    case OnRowChange:        return d->setRecord(row, record);    case OnManualSubmit: {        QSqlTableModelPrivate::ModifiedRow &mrow = d->cache[row];        if (mrow.op == QSqlTableModelPrivate::None) {            mrow.op = QSqlTableModelPrivate::Update;            mrow.rec = d->rec;        }        for (int i = 0; i < record.count(); ++i) {            int idx = mrow.rec.indexOf(record.fieldName(i));            if (idx == -1)                isOk = false;            else                mrow.rec.setValue(idx, record.value(i));        }        return isOk; }    }    return false;}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品视频一区二区三区不卡| 久久综合九色综合欧美亚洲| 国产精品亚洲成人| 免费人成在线不卡| 婷婷丁香激情综合| 日韩国产在线一| 日日夜夜免费精品视频| 亚洲综合一区二区三区| 亚洲欧洲日产国产综合网| 国产精品护士白丝一区av| 国产精品亲子伦对白| 国产精品免费丝袜| 亚洲天堂免费看| 亚洲激情在线激情| 一二三四区精品视频| 视频一区二区三区入口| 日本亚洲天堂网| 国产乱淫av一区二区三区| 国产老妇另类xxxxx| 成人一区在线观看| 91麻豆精品在线观看| 91久久免费观看| 制服丝袜国产精品| 欧美精品一区二区三区在线| 久久免费精品国产久精品久久久久 | 国产精品色婷婷| 亚洲视频一区在线观看| 亚洲电影中文字幕在线观看| 日韩电影在线观看一区| 国产一区二区三区在线观看免费视频 | 亚洲一区二区精品久久av| 亚洲va欧美va国产va天堂影院| 日本不卡高清视频| 国产91精品精华液一区二区三区| 色综合av在线| 日韩三级在线免费观看| 国产精品无遮挡| 亚洲成人一区二区在线观看| 久久精品国产精品亚洲红杏| av资源站一区| 欧美精品自拍偷拍| 国产精品少妇自拍| 免费在线观看日韩欧美| 成人精品小蝌蚪| 欧美美女直播网站| 国产精品区一区二区三| 偷拍一区二区三区| 丁香婷婷综合激情五月色| 91精彩视频在线| 久久精品亚洲一区二区三区浴池| 亚洲五码中文字幕| 成人综合在线观看| 日韩精品专区在线| 亚洲国产精品天堂| 成人精品视频一区| 精品国产制服丝袜高跟| 亚洲精品欧美综合四区| 国产成人午夜精品影院观看视频| 欧美日韩国产免费一区二区| 久久精品亚洲国产奇米99| 亚洲第一搞黄网站| 91色.com| 国产精品另类一区| 国产精品一区二区久久不卡 | 亚洲精品国产a| 国产成人精品www牛牛影视| 91精品国产综合久久久久久| 中文字幕综合网| 成人一级片在线观看| 久久久精品免费网站| 另类专区欧美蜜桃臀第一页| 欧美日韩一区二区不卡| 亚洲精选视频在线| 成人精品免费看| 久久精品人人做人人综合| 久久国产精品色| 欧美成人艳星乳罩| 九九九久久久精品| 日韩午夜激情电影| 免费观看一级欧美片| 在线综合视频播放| 天天av天天翘天天综合网色鬼国产| 一本一本大道香蕉久在线精品| 国产精品动漫网站| 成人精品视频网站| 亚洲欧美国产三级| 91麻豆国产在线观看| 自拍偷拍国产精品| 欧美在线观看视频一区二区三区| 亚洲免费观看视频| 欧美性高清videossexo| 丝袜亚洲精品中文字幕一区| 欧美日韩免费观看一区三区| 视频在线观看国产精品| 精品日韩在线一区| 国产美女在线观看一区| 欧美极品xxx| 色婷婷香蕉在线一区二区| 亚洲影视资源网| 欧美一个色资源| 久久精品国产99| 日本一二三不卡| 91在线观看一区二区| 亚洲最大的成人av| 在线不卡免费欧美| 国内久久婷婷综合| 亚洲欧美综合色| 欧美视频你懂的| 日本欧美一区二区在线观看| 久久综合久久99| 91网站最新网址| 天天色天天操综合| 久久久www免费人成精品| 99这里只有久久精品视频| 亚洲黄色性网站| 337p日本欧洲亚洲大胆精品 | 欧美色爱综合网| 精品无人码麻豆乱码1区2区| 亚洲国产精品传媒在线观看| 91久久精品一区二区| 蜜乳av一区二区| 国产精品入口麻豆九色| 欧美日韩二区三区| 风流少妇一区二区| 日本特黄久久久高潮| 国产片一区二区三区| 欧美久久久久久久久久 | 日本vs亚洲vs韩国一区三区二区| 久久久久久久综合| 欧美日韩一区久久| 成人小视频在线| 蜜臀久久99精品久久久画质超高清| 国产亚洲自拍一区| 91麻豆精品国产自产在线观看一区| 成人综合婷婷国产精品久久| 日韩精品国产精品| 亚洲免费三区一区二区| 久久精品免费在线观看| 欧美精品一二三| 色乱码一区二区三区88 | 久久精品国产秦先生| 亚洲小说春色综合另类电影| 欧美zozo另类异族| 欧美高清你懂得| 在线日韩一区二区| 成人免费va视频| 国产尤物一区二区| 日韩精品亚洲一区| 一级女性全黄久久生活片免费| 中文一区一区三区高中清不卡| 日韩美女视频在线| 日韩一区二区不卡| 欧美精品亚洲二区| 欧美日本免费一区二区三区| 色综合激情久久| 91麻豆国产福利精品| 粉嫩aⅴ一区二区三区四区五区| 激情都市一区二区| 精品一区二区三区免费观看| 婷婷综合五月天| 日韩va亚洲va欧美va久久| 亚洲成人一区二区| 香蕉久久夜色精品国产使用方法 | 成人av电影在线播放| 国产一区二区成人久久免费影院| 日韩精品免费视频人成| 日韩高清电影一区| 日韩avvvv在线播放| 轻轻草成人在线| 蜜臂av日日欢夜夜爽一区| 免费高清成人在线| 韩国精品一区二区| 国产精品一线二线三线精华| 激情国产一区二区| 丰满亚洲少妇av| 91亚洲精品久久久蜜桃网站| 色欧美乱欧美15图片| 欧洲日韩一区二区三区| 欧美日本一区二区三区四区| 91.com在线观看| 精品国产91乱码一区二区三区| 欧美tickling挠脚心丨vk| 国产亚洲欧洲一区高清在线观看| 国产午夜精品一区二区三区嫩草 | 欧美一级视频精品观看| 精品国产91久久久久久久妲己 | 韩日欧美一区二区三区| 国产91在线观看| 91成人看片片| 欧美不卡一区二区三区四区| 久久久久一区二区三区四区| 国产欧美日韩三区| 亚洲精品欧美专区| 精品伊人久久久久7777人| 懂色av一区二区夜夜嗨| 欧美中文字幕久久| 欧美大片顶级少妇| 亚洲天堂网中文字| 日韩av网站在线观看| 成人激情小说网站|