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

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

?? qsqldatabase.cpp

?? QT 開發(fā)環(huán)境里面一個很重要的文件
?? CPP
?? 第 1 頁 / 共 3 頁
字號:
QStringList QSqlDatabase::drivers(){    QStringList list;#ifdef QT_SQL_PSQL    list << QLatin1String("QPSQL7");    list << QLatin1String("QPSQL");#endif#ifdef QT_SQL_MYSQL    list << QLatin1String("QMYSQL3");    list << QLatin1String("QMYSQL");#endif#ifdef QT_SQL_ODBC    list << QLatin1String("QODBC3");    list << QLatin1String("QODBC");#endif#ifdef QT_SQL_OCI    list << QLatin1String("QOCI8");    list << QLatin1String("QOCI");#endif#ifdef QT_SQL_TDS    list << QLatin1String("QTDS7");    list << QLatin1String("QTDS");#endif#ifdef QT_SQL_DB2    list << QLatin1String("QDB2");#endif#ifdef QT_SQL_SQLITE    list << QLatin1String("QSQLITE");#endif#ifdef QT_SQL_SQLITE2    list << QLatin1String("QSQLITE2");#endif#ifdef QT_SQL_IBASE    list << QLatin1String("QIBASE");#endif#ifndef QT_NO_LIBRARY    if (QFactoryLoader *fl = loader()) {        QStringList keys = fl->keys();        for (QStringList::const_iterator i = keys.constBegin(); i != keys.constEnd(); ++i) {            if (!list.contains(*i))                list << *i;        }    }#endif    DriverDict dict = QSqlDatabasePrivate::driverDict();    for (DriverDict::const_iterator i = dict.constBegin(); i != dict.constEnd(); ++i) {        if (!list.contains(i.key()))            list << i.key();    }    return list;}/*!    This function registers a new SQL driver called \a name, within    the SQL framework. This is useful if you have a custom SQL driver    and don't want to compile it as a plugin.    Example:    \code    QSqlDatabase::registerSqlDriver("MYDRIVER",                                    new QSqlDriverCreator<MyDatabaseDriver>);    QSqlDatabase db = QSqlDatabase::addDatabase("MYDRIVER");    \endcode    QSqlDatabase takes ownership of the \a creator pointer, so you    mustn't delete it yourself.    \sa drivers()*/void QSqlDatabase::registerSqlDriver(const QString& name, QSqlDriverCreatorBase *creator){    delete QSqlDatabasePrivate::driverDict().take(name);    if (creator)        QSqlDatabasePrivate::driverDict().insert(name, creator);}/*!    \threadsafe    Returns true if the list of database connections contains \a    connectionName; otherwise returns false.    \sa connectionNames(), database()*/bool QSqlDatabase::contains(const QString& connectionName){    return QSqlDatabasePrivate::dbDict()->contains_ts(connectionName);}/*!    \threadsafe    Returns a list containing the names of all connections.    \sa contains(), database()*/QStringList QSqlDatabase::connectionNames(){    return QSqlDatabasePrivate::dbDict()->keys_ts();}/*!    \overload    Creates a QSqlDatabase connection that uses the driver referred    to by \a type. If the \a type is not recognized, the database    connection will have no functionality.    The currently available driver types are:    \table    \header \i Driver Type \i Description    \row \i QDB2     \i IBM DB2    \row \i QIBASE   \i Borland InterBase Driver    \row \i QMYSQL   \i MySQL Driver    \row \i QOCI     \i Oracle Call Interface Driver    \row \i QODBC    \i ODBC Driver (includes Microsoft SQL Server)    \row \i QPSQL    \i PostgreSQL Driver    \row \i QSQLITE  \i SQLite version 3 or above    \row \i QSQLITE2 \i SQLite version 2    \row \i QTDS     \i Sybase Adaptive Server    \endtable    Additional third party drivers, including your own custom    drivers, can be loaded dynamically.    \sa {SQL Database Drivers}, registerSqlDriver(), drivers()*/QSqlDatabase::QSqlDatabase(const QString &type){    d = new QSqlDatabasePrivate();    d->init(type);}/*!    \overload    Creates a database connection using the given \a driver.*/QSqlDatabase::QSqlDatabase(QSqlDriver *driver){    d = new QSqlDatabasePrivate(driver);}/*!    Creates an empty, invalid QSqlDatabase object. Use addDatabase(),    removeDatabase(), and database() to get valid QSqlDatabase    objects.*/QSqlDatabase::QSqlDatabase(){    d = QSqlDatabasePrivate::shared_null();    d->ref.ref();}/*!    Creates a copy of \a other.*/QSqlDatabase::QSqlDatabase(const QSqlDatabase &other){    d = other.d;    d->ref.ref();}/*!    Assigns \a other to this object.*/QSqlDatabase &QSqlDatabase::operator=(const QSqlDatabase &other){    qAtomicAssign(d, other.d);    return *this;}/*!    \internal    Create the actual driver instance \a type.*/void QSqlDatabasePrivate::init(const QString &type){    drvName = type;    if (!driver) {#ifdef QT_SQL_PSQL        if (type == QLatin1String("QPSQL") || type == QLatin1String("QPSQL7"))            driver = new QPSQLDriver();#endif#ifdef QT_SQL_MYSQL        if (type == QLatin1String("QMYSQL") || type == QLatin1String("QMYSQL3"))            driver = new QMYSQLDriver();#endif#ifdef QT_SQL_ODBC        if (type == QLatin1String("QODBC") || type == QLatin1String("QODBC3"))            driver = new QODBCDriver();#endif#ifdef QT_SQL_OCI        if (type == QLatin1String("QOCI") || type == QLatin1String("QOCI8"))            driver = new QOCIDriver();#endif#ifdef QT_SQL_TDS        if (type == QLatin1String("QTDS") || type == QLatin1String("QTDS7"))            driver = new QTDSDriver();#endif#ifdef QT_SQL_DB2        if (type == QLatin1String("QDB2"))            driver = new QDB2Driver();#endif#ifdef QT_SQL_SQLITE        if (type == QLatin1String("QSQLITE"))            driver = new QSQLiteDriver();#endif#ifdef QT_SQL_SQLITE2        if (type == QLatin1String("QSQLITE2"))            driver = new QSQLite2Driver();#endif#ifdef QT_SQL_IBASE        if (type == QLatin1String("QIBASE"))            driver = new QIBaseDriver();#endif    }    if (!driver) {        DriverDict dict = QSqlDatabasePrivate::driverDict();        for (DriverDict::const_iterator it = dict.constBegin();             it != dict.constEnd() && !driver; ++it) {            if (type == it.key()) {                driver = ((QSqlDriverCreatorBase*)(*it))->createObject();            }        }    }#ifndef QT_NO_LIBRARY    if (!driver && loader()) {        if (QSqlDriverFactoryInterface *factory = qobject_cast<QSqlDriverFactoryInterface*>(loader()->instance(type)))            driver = factory->create(type);    }#endif // QT_NO_LIBRARY    if (!driver) {        qWarning("QSqlDatabase: %s driver not loaded", type.toLatin1().data());        qWarning("QSqlDatabase: available drivers: %s",                        QSqlDatabase::drivers().join(QLatin1String(" ")).toLatin1().data());        driver = shared_null()->driver;    }}/*!    Destroys the object and frees any allocated resources.    If this is the last QSqlDatabase object that uses a certain    database connection, the is automatically closed.    \sa close()*/QSqlDatabase::~QSqlDatabase(){    if (!d->ref.deref()) {        close();        delete d;    }}/*!    Executes a SQL statement on the database and returns a QSqlQuery    object. Use lastError() to retrieve error information. If \a    query is empty, an empty, invalid query is returned and    lastError() is not affected.    \sa QSqlQuery, lastError()*/QSqlQuery QSqlDatabase::exec(const QString & query) const{    QSqlQuery r(d->driver->createResult());    if (!query.isEmpty()) {        r.exec(query);        d->driver->setLastError(r.lastError());    }    return r;}/*!    Opens the database connection using the current connection    values. Returns true on success; otherwise returns false. Error    information can be retrieved using lastError().    \sa lastError() setDatabaseName() setUserName() setPassword() setHostName() setPort() setConnectOptions()*/bool QSqlDatabase::open(){    return d->driver->open(d->dbname, d->uname, d->pword, d->hname,                            d->port, d->connOptions);}/*!    \overload    Opens the database connection using the given \a user name and \a    password. Returns true on success; otherwise returns false. Error    information can be retrieved using the lastError() function.    This function does not store the password it is given. Instead,    the password is passed directly to the driver for opening the    connection and it is then discarded.    \sa lastError()*/bool QSqlDatabase::open(const QString& user, const QString& password){    setUserName(user);    return d->driver->open(d->dbname, user, password, d->hname,                            d->port, d->connOptions);}/*!    Closes the database connection, freeing any resources acquired.    This will also affect copies of this QSqlDatabase object.    \sa removeDatabase()*/void QSqlDatabase::close(){    d->driver->close();}/*!    Returns true if the database connection is currently open;    otherwise returns false.*/bool QSqlDatabase::isOpen() const{    return d->driver->isOpen();}/*!    Returns true if there was an error opening the database    connection; otherwise returns false. Error information can be    retrieved using the lastError() function.*/bool QSqlDatabase::isOpenError() const{    return d->driver->isOpenError();}/*!    Begins a transaction on the database if the driver supports    transactions. Returns true if the operation succeeded; otherwise    returns false.    \sa QSqlDriver::hasFeature(), commit(), rollback()*/bool QSqlDatabase::transaction(){    if (!d->driver->hasFeature(QSqlDriver::Transactions))        return false;    return d->driver->beginTransaction();}/*!    Commits a transaction to the database if the driver supports    transactions and a transaction() has been started. Returns true if    the operation succeeded; otherwise returns false.    Note that on some databases, this function will not work if there    is an active QSqlQuery on the database. Use the lastError()    function to retrieve database-specific error data about the error    that occurred.    \sa QSqlDriver::hasFeature() rollback()*/bool QSqlDatabase::commit(){    if (!d->driver->hasFeature(QSqlDriver::Transactions))        return false;    return d->driver->commitTransaction();}/*!    Rolls a transaction back on the database if the driver supports    transactions and a transaction() has been started. Returns true    if the operation succeeded; otherwise returns false.    \sa QSqlDriver::hasFeature() commit()*/bool QSqlDatabase::rollback(){    if (!d->driver->hasFeature(QSqlDriver::Transactions))        return false;    return d->driver->rollbackTransaction();}/*!    Sets the connection's name to \a name. This must be done before    the connection is opened or it has no effect; (or you can close()    the connection, call this function and open() the connection    again). The name is database-specific.    For the QOCI (Oracle) driver, the database name is the TNS    Service Name.    For the QODBC driver, the \a name can either be a DSN, a DSN    filename (in which case the file must have a \c .dsn extension),    or a connection string.    For example, Microsoft Access users can use the following    connection string to open an \c .mdb file directly, instead of    having to create a DSN entry in the ODBC manager:    \code    ...    db = QSqlDatabase::addDatabase("QODBC");    db.setDatabaseName("DRIVER={Microsoft Access Driver (*.mdb)};FIL={MS Access};DBQ=myaccessfile.mdb");    if (db.open()) {        // success!    }    ...    \endcode    There is no default value.    \sa databaseName() setUserName() setPassword() setHostName() setPort() setConnectOptions() open()*/void QSqlDatabase::setDatabaseName(const QString& name){    if (isValid())        d->dbname = name;}/*!    Sets the connection's user name to \a name. This must be done    before the connection is opened or it has no effect (or you can    close() the connection, call this function and open() the    connection again).    There is no default value.    \sa userName() setDatabaseName() setPassword() setHostName()    setPort() setConnectOptions() open()*/void QSqlDatabase::setUserName(const QString& name){    if (isValid())        d->uname = name;}/*!    Sets the connection's password to \a password. This must be done    before the connection is opened or it has no effect (or you can    close() the connection, call this function and open() the    connection again).    There is no default value.    \warning This function stores the password in plain text within    Qt. Use the open() call that takes a password as parameter to    avoid this behavior.    \sa password() setUserName() setDatabaseName() setHostName() setPort() setConnectOptions() open()*/void QSqlDatabase::setPassword(const QString& password){    if (isValid())        d->pword = password;}/*!    Sets the connection's host name to \a host. This must be done    before the connection is opened or it has no effect (or you can

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品成人一区二区三区| 天天综合网 天天综合色| 亚洲激情网站免费观看| 麻豆成人综合网| 91免费观看视频在线| 久久久久久**毛片大全| 亚洲r级在线视频| aa级大片欧美| 中文字幕欧美三区| 国产最新精品精品你懂的| 欧美日本一区二区在线观看| 亚洲天堂网中文字| 成人福利视频网站| 欧美国产精品中文字幕| 国产精品资源站在线| 日韩一区二区三| 日韩二区三区在线观看| 精品视频一区二区不卡| 一区二区三区欧美在线观看| av在线播放不卡| 国产精品高潮呻吟久久| 国产福利精品一区二区| 国产日本亚洲高清| 国产成人av一区二区三区在线 | 亚洲小说欧美激情另类| av不卡在线播放| 国产精品欧美精品| 99久久婷婷国产| 国产精品国产三级国产普通话蜜臀 | 精品免费国产二区三区| 美女在线视频一区| 日韩三级电影网址| 国产最新精品精品你懂的| 欧美本精品男人aⅴ天堂| 麻豆成人av在线| www国产成人免费观看视频 深夜成人网| 免费xxxx性欧美18vr| 日韩久久久久久| 国产精品一二二区| 中文字幕一区二区三区在线播放 | 4438x亚洲最大成人网| 亚洲电影你懂得| 欧美猛男gaygay网站| 美女诱惑一区二区| www欧美成人18+| av不卡一区二区三区| 尤物av一区二区| 日韩视频在线你懂得| 精品综合久久久久久8888| 久久久久久久电影| 91片在线免费观看| 人人超碰91尤物精品国产| 精品999在线播放| 99国产精品99久久久久久| 亚洲国产综合视频在线观看| 欧美一区二区三区性视频| 精彩视频一区二区三区| 欧美激情综合网| 精品视频一区二区三区免费| 日韩中文字幕区一区有砖一区| 欧美精品一区二区在线播放| 成人精品一区二区三区中文字幕| 亚洲免费观看高清在线观看| 日韩欧美自拍偷拍| 91在线你懂得| 精品系列免费在线观看| 亚洲精品日日夜夜| 久久精品亚洲乱码伦伦中文 | 日本久久一区二区| 蜜桃精品在线观看| 亚洲视频电影在线| 日韩片之四级片| 日本韩国一区二区三区| 久久国产福利国产秒拍| 亚洲精品久久久蜜桃| 精品免费日韩av| 在线观看av一区| 国产999精品久久| 青青草成人在线观看| 国产精品久久久久三级| 欧美电视剧在线观看完整版| 91在线免费播放| 国产精品99精品久久免费| 亚洲国产一区二区三区| 综合久久给合久久狠狠狠97色| 日韩一区二区在线观看| 欧美亚洲禁片免费| 99久久er热在这里只有精品15| 久久精品国产免费| 五月激情丁香一区二区三区| 国产精品久久久久影院色老大| 精品噜噜噜噜久久久久久久久试看 | 欧美日韩免费观看一区二区三区 | 日本一区二区成人在线| 91精品国产高清一区二区三区蜜臀 | 午夜精品久久久久久久久| 国产精品久久久久桃色tv| 精品捆绑美女sm三区| 欧美日韩电影一区| 欧美性三三影院| 91高清视频在线| 色婷婷精品久久二区二区蜜臀av | 激情综合网av| 秋霞午夜av一区二区三区| 亚洲mv在线观看| 亚洲二区视频在线| 亚洲第一福利一区| 亚洲福利一二三区| 午夜精品久久久久久久蜜桃app| 亚洲一区二区在线视频| 亚洲最大色网站| 亚洲高清免费观看高清完整版在线观看 | 久久亚洲一区二区三区四区| 日韩亚洲欧美在线| 精品国产第一区二区三区观看体验| 制服丝袜一区二区三区| 91精品婷婷国产综合久久性色| 制服丝袜一区二区三区| 欧美一区二区三区四区高清| 日韩三级在线观看| 久久久影视传媒| 中文字幕日韩一区| 亚洲资源中文字幕| 亚洲va国产天堂va久久en| 日韩av电影免费观看高清完整版| 免费久久99精品国产| 国产精品亚洲午夜一区二区三区 | 亚洲欧美日韩精品久久久久| 一区二区三区在线免费| 亚洲国产精品一区二区久久恐怖片| 亚洲一区二区av电影| 首页国产欧美久久| 国产中文字幕一区| 91一区二区在线观看| 欧美亚洲综合久久| 日韩欧美国产三级电影视频| 久久免费电影网| 亚洲久草在线视频| 色诱视频网站一区| 欧美日本国产视频| 久久嫩草精品久久久精品一| 亚洲欧美一区二区视频| 丝袜美腿亚洲色图| 国产成人av一区二区| 在线免费观看日本欧美| 日韩午夜在线播放| |精品福利一区二区三区| 午夜精品123| 国产一二三精品| 在线欧美小视频| 久久一二三国产| 亚洲国产精品久久不卡毛片 | 国产一区二区三区香蕉| 波多野结衣中文字幕一区二区三区 | 国产综合色精品一区二区三区| eeuss国产一区二区三区| 欧美日韩不卡一区二区| 国产欧美在线观看一区| 亚洲香肠在线观看| 国产a级毛片一区| 91精品国产色综合久久| 亚洲视频在线观看一区| 久久国产精品免费| 欧美撒尿777hd撒尿| 亚洲国产高清aⅴ视频| 青青草原综合久久大伊人精品优势 | 亚洲欧美日韩在线播放| 精品一区二区免费看| 欧美欧美欧美欧美| 亚洲欧美日韩国产另类专区| 激情文学综合网| 欧美调教femdomvk| 亚洲欧美一区二区三区极速播放| 久草精品在线观看| 欧美人xxxx| 亚洲一二三四久久| 99热99精品| 欧美国产丝袜视频| 久久国产精品99久久久久久老狼| 欧美丝袜第三区| 亚洲免费色视频| 99久久精品国产网站| 欧美国产丝袜视频| 成人综合在线视频| 久久精品夜夜夜夜久久| 国产美女精品在线| 久久无码av三级| 国产精品正在播放| 久久九九国产精品| 国产精品一级黄| 国产区在线观看成人精品| 91精品国产乱码| 青青草国产成人av片免费| 欧美二区在线观看| 麻豆成人综合网| 久久这里只有精品6| 国产高清无密码一区二区三区| 2023国产一二三区日本精品2022| 精品一区二区三区在线播放 | 91精品国产综合久久久久久久|