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

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

?? qsql_mysql.cpp

?? Trolltech公司發布的基于C++圖形開發環境
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
/******************************************************************************** Implementation of MYSQL driver classes**** Created : 001103**** Copyright (C) 1992-2000 Trolltech AS.  All rights reserved.**** This file is part of the sql module of the Qt GUI Toolkit.**** This file may be distributed under the terms of the Q Public License** as defined by Trolltech AS of Norway and appearing in the file** LICENSE.QPL included in the packaging of this file.**** This file may be distributed and/or modified under the terms of the** GNU General Public License version 2 as published by the Free Software** Foundation and appearing in the file LICENSE.GPL included in the** packaging of this file.**** Licensees holding valid Qt Enterprise Edition licenses may use this** file in accordance with the Qt Commercial License Agreement provided** with the Software.**** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.**** See http://www.trolltech.com/pricing.html or email sales@trolltech.com for**   information about Qt Commercial License Agreements.** See http://www.trolltech.com/qpl/ for QPL licensing information.** See http://www.trolltech.com/gpl/ for GPL licensing information.**** Contact info@trolltech.com if any conditions of this licensing are** not clear to you.************************************************************************/#include "qsql_mysql.h"#include <private/qsqlextension_p.h>#include <qdatetime.h>#include <qvaluevector.h>#include <qsqlrecord.h>#define QMYSQL_DRIVER_NAME "QMYSQL3"#ifdef Q_OS_WIN32// comment the next line out if you want to use MySQL/embedded on Win32 systems.// note that it will crash if you don't statically link to the mysql/e library!# define Q_NO_MYSQL_EMBEDDED#endifQPtrDict<QSqlOpenExtension> *qSqlOpenExtDict();class QMYSQLOpenExtension : public QSqlOpenExtension{public:    QMYSQLOpenExtension( QMYSQLDriver *dri )	: QSqlOpenExtension(), driver(dri) {}    ~QMYSQLOpenExtension() {}    bool open( const QString& db,	       const QString& user,	       const QString& password,	       const QString& host,	       int port,	       const QString& connOpts );    private:    QMYSQLDriver *driver;};bool QMYSQLOpenExtension::open( const QString& db,				const QString& user,				const QString& password,				const QString& host,				int port,				const QString& connOpts ){    return driver->open( db, user, password, host, port, connOpts );}class QMYSQLDriverPrivate{public:    QMYSQLDriverPrivate() : mysql(0) {}    MYSQL*     mysql;};class QMYSQLResultPrivate : public QMYSQLDriverPrivate{public:    QMYSQLResultPrivate() : QMYSQLDriverPrivate(), result(0) {}    MYSQL_RES* result;    MYSQL_ROW  row;    QValueVector<QVariant::Type> fieldTypes;};QSqlError qMakeError( const QString& err, int type, const QMYSQLDriverPrivate* p ){    return QSqlError(QMYSQL_DRIVER_NAME ": " + err, QString(mysql_error( p->mysql )), type, mysql_errno( p->mysql ));}QVariant::Type qDecodeMYSQLType( int mysqltype, uint flags ){    QVariant::Type type;    switch ( mysqltype ) {    case FIELD_TYPE_TINY :    case FIELD_TYPE_SHORT :    case FIELD_TYPE_LONG :    case FIELD_TYPE_INT24 :	type = (flags & UNSIGNED_FLAG) ? QVariant::UInt : QVariant::Int;	break;    case FIELD_TYPE_YEAR :	type = QVariant::Int;	break;    case FIELD_TYPE_LONGLONG :	type = (flags & UNSIGNED_FLAG) ? QVariant::ULongLong : QVariant::LongLong;	break;    case FIELD_TYPE_DECIMAL :    case FIELD_TYPE_FLOAT :    case FIELD_TYPE_DOUBLE :	type = QVariant::Double;	break;    case FIELD_TYPE_DATE :	type = QVariant::Date;	break;    case FIELD_TYPE_TIME :	type = QVariant::Time;	break;    case FIELD_TYPE_DATETIME :    case FIELD_TYPE_TIMESTAMP :	type = QVariant::DateTime;	break;    case FIELD_TYPE_BLOB :    case FIELD_TYPE_TINY_BLOB :    case FIELD_TYPE_MEDIUM_BLOB :    case FIELD_TYPE_LONG_BLOB :	type = (flags & BINARY_FLAG) ? QVariant::ByteArray : QVariant::CString;	break;    default:    case FIELD_TYPE_ENUM :    case FIELD_TYPE_SET :    case FIELD_TYPE_STRING :    case FIELD_TYPE_VAR_STRING :	type = QVariant::String;	break;    }    return type;}QMYSQLResult::QMYSQLResult( const QMYSQLDriver* db ): QSqlResult( db ){    d =   new QMYSQLResultPrivate();    d->mysql = db->d->mysql;}QMYSQLResult::~QMYSQLResult(){    cleanup();    delete d;}MYSQL_RES* QMYSQLResult::result(){    return d->result;}void QMYSQLResult::cleanup(){    if ( d->result ) {	mysql_free_result( d->result );    }    d->result = NULL;    d->row = NULL;    setAt( -1 );    setActive( FALSE );}bool QMYSQLResult::fetch( int i ){    if ( isForwardOnly() ) { // fake a forward seek	if ( at() < i ) {	    int x = i - at();	    while ( --x && fetchNext() );	    return fetchNext();	} else {	    return FALSE;	}    }        if ( at() == i )	return TRUE;    mysql_data_seek( d->result, i );    d->row = mysql_fetch_row( d->result );    if ( !d->row )	return FALSE;    setAt( i );    return TRUE;}bool QMYSQLResult::fetchNext(){    d->row = mysql_fetch_row( d->result );    if ( !d->row )	return FALSE;    setAt( at() + 1 );    return TRUE;}bool QMYSQLResult::fetchLast(){    if ( isForwardOnly() ) { // fake this since MySQL can't seek on forward only queries	bool success = fetchNext(); // did we move at all?	while ( fetchNext() );	return success;    }    my_ulonglong numRows = mysql_num_rows( d->result );    if ( !numRows )	return FALSE;    return fetch( numRows - 1 );}bool QMYSQLResult::fetchFirst(){    if ( isForwardOnly() ) // again, fake it	return fetchNext();    return fetch( 0 );}QVariant QMYSQLResult::data( int field ){    if ( !isSelect() || field >= (int) d->fieldTypes.count() ) {	qWarning( "QMYSQLResult::data: column %d out of range", field );	return QVariant();    }        QString val( d->row[field] );    switch ( d->fieldTypes.at( field ) ) {    case QVariant::LongLong:	return QVariant( val.toLongLong() );    case QVariant::ULongLong:	return QVariant( val.toULongLong() );    case QVariant::Int: 	return QVariant( val.toInt() );    case QVariant::UInt:	return QVariant( val.toUInt() );    case QVariant::Double:	return QVariant( val.toDouble() );    case QVariant::Date:	if ( val.isEmpty() ) {	    return QVariant( QDate() );	} else {	    return QVariant( QDate::fromString( val, Qt::ISODate )  );	}    case QVariant::Time:	if ( val.isEmpty() ) {	    return QVariant( QTime() );	} else {	    return QVariant( QTime::fromString( val, Qt::ISODate ) );	}    case QVariant::DateTime:	if ( val.isEmpty() )	    return QVariant( QDateTime() );	if ( val.length() == 14u )	    // TIMESTAMPS have the format yyyyMMddhhmmss	    val.insert(4, "-").insert(7, "-").insert(10, 'T').insert(13, ':').insert(16, ':');	return QVariant( QDateTime::fromString( val, Qt::ISODate ) );    case QVariant::ByteArray: {	unsigned long* fl = mysql_fetch_lengths( d->result );	QByteArray ba;	ba.duplicate( d->row[field], fl[field] );	return QVariant( ba );    }    default:    case QVariant::String:    case QVariant::CString:	return QVariant( val );    }#ifdef QT_CHECK_RANGE    qWarning("QMYSQLResult::data: unknown data type");#endif    return QVariant();}bool QMYSQLResult::isNull( int field ){    if ( d->row[field] == NULL )	return TRUE;    return FALSE;}bool QMYSQLResult::reset ( const QString& query ){    if ( !driver() )	return FALSE;    if ( !driver()-> isOpen() || driver()->isOpenError() )	return FALSE;    cleanup();    if ( mysql_real_query( d->mysql, query, query.length() ) ) {	setLastError( qMakeError("Unable to execute query", QSqlError::Statement, d ) );	return FALSE;    }    if ( isForwardOnly() ) { 	if ( isActive() || isValid() ) // have to empty the results from previous query	    fetchLast(); 	d->result = mysql_use_result( d->mysql );    } else {	d->result = mysql_store_result( d->mysql );    }    if ( !d->result && mysql_field_count( d->mysql ) > 0 ) {	setLastError( qMakeError( "Unable to store result", QSqlError::Statement, d ) );	return FALSE;    }    int numFields = mysql_field_count( d->mysql );    setSelect( !( numFields == 0) );    d->fieldTypes.resize( numFields );    if ( isSelect() ) {	for( int i = 0; i < numFields; i++) {	    MYSQL_FIELD* field = mysql_fetch_field_direct( d->result, i );	    if ( field->type == FIELD_TYPE_DECIMAL )		d->fieldTypes[i] = QVariant::String;	    else		d->fieldTypes[i] = qDecodeMYSQLType( field->type, field->flags );	}    }    setActive( TRUE );    return TRUE;}int QMYSQLResult::size(){    return isSelect() ? (int)mysql_num_rows( d->result ) : -1;}int QMYSQLResult::numRowsAffected(){    return (int)mysql_affected_rows( d->mysql );}/////////////////////////////////////////////////////////static void qServerInit(){#ifndef Q_NO_MYSQL_EMBEDDED# if MYSQL_VERSION_ID >= 40000    static bool init = FALSE;    if ( init )	return;    // this should only be called once    // has no effect on client/server library    // but is vital for the embedded lib    if ( mysql_server_init( 0, 0, 0 ) ) {#  ifdef QT_CHECK_RANGE	qWarning( "QMYSQLDriver::qServerInit: unable to start server." );#  endif    }    init = TRUE;    # endif // MYSQL_VERSION_ID#endif // Q_NO_MYSQL_EMBEDDED}QMYSQLDriver::QMYSQLDriver( QObject * parent, const char * name )    : QSqlDriver( parent, name ? name : QMYSQL_DRIVER_NAME ){    init();    qServerInit();}/*!    Create a driver instance with an already open connection handle.*/QMYSQLDriver::QMYSQLDriver( MYSQL * con, QObject * parent, const char * name )    : QSqlDriver( parent, name ? name : QMYSQL_DRIVER_NAME ){    init();    if ( con ) {	d->mysql = (MYSQL *) con;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产成人在线视频网站| 精品视频色一区| 久久网站最新地址| 亚洲国产另类av| 欧美猛男男办公室激情| 国产综合成人久久大片91| 精品福利av导航| 91老师片黄在线观看| 久久99久久99精品免视看婷婷 | thepron国产精品| 亚洲国产一区二区视频| 欧美经典三级视频一区二区三区| 成人激情动漫在线观看| 日韩影院免费视频| 亚洲一区免费观看| 成人欧美一区二区三区| 2024国产精品| 91精品国产一区二区| 在线观看亚洲一区| 91免费观看视频在线| 粉嫩av亚洲一区二区图片| 精品影视av免费| 久草中文综合在线| 久久成人18免费观看| 久久国产生活片100| 美脚の诱脚舐め脚责91| 日本在线不卡一区| 久久丁香综合五月国产三级网站| 日韩不卡一区二区三区| 亚洲香肠在线观看| 日韩电影在线免费| 香蕉久久一区二区不卡无毒影院| 亚洲一区在线电影| 蜜臀va亚洲va欧美va天堂| 人人狠狠综合久久亚洲| 免费观看日韩av| 成人在线视频一区| 欧美中文字幕一区二区三区 | 亚洲男人都懂的| 日韩精品色哟哟| 国产成人免费视频一区| 一本大道久久a久久综合| 欧美影视一区二区三区| www国产亚洲精品久久麻豆| 国产精品天天看| 日韩国产精品久久| 91免费视频大全| 欧美不卡123| 国产精品日日摸夜夜摸av| 亚洲va韩国va欧美va精品| 黑人巨大精品欧美一区| 91麻豆国产福利在线观看| 欧美一区二区大片| 亚洲自拍偷拍av| 波多野结衣精品在线| 欧美成人官网二区| 日本成人中文字幕| 欧美午夜影院一区| 亚洲色图欧美激情| 成人av午夜电影| 久久精品人人做人人综合 | 成人午夜av电影| 精品卡一卡二卡三卡四在线| 亚洲成人三级小说| 91麻豆精品国产91久久久久久 | av亚洲精华国产精华精| 99精品久久久久久| 久久久99久久精品欧美| 亚洲福利一区二区三区| 欧美中文一区二区三区| 日韩毛片精品高清免费| 国产精品香蕉一区二区三区| 欧美日韩精品一区二区三区四区| 欧美国产1区2区| 国产成a人亚洲| 久久精品欧美一区二区三区不卡| 奇米精品一区二区三区在线观看 | 日韩av中文字幕一区二区| 欧洲色大大久久| 亚洲一区二区三区中文字幕在线| 色天使色偷偷av一区二区| 夜夜亚洲天天久久| 在线成人免费视频| 国产精品一品视频| 国产精品电影一区二区三区| 色综合色综合色综合色综合色综合| 亚洲美女免费在线| 91精品国产欧美一区二区| 久久精品国产精品亚洲精品| 国产精品五月天| 在线精品视频免费播放| 另类小说视频一区二区| 亚洲欧美日韩中文字幕一区二区三区 | 丁香啪啪综合成人亚洲小说| 日韩一区在线免费观看| 7777精品伊人久久久大香线蕉超级流畅 | 97国产一区二区| 久久国产人妖系列| 亚洲综合久久av| 国产精品国模大尺度视频| 51午夜精品国产| 91老司机福利 在线| 国产精品一区二区你懂的| 亚洲成人黄色影院| 亚洲美女免费视频| 中文字幕日本不卡| 国产精品美日韩| 国产午夜亚洲精品理论片色戒 | 91在线视频官网| 成人免费观看视频| bt7086福利一区国产| 国产一区不卡精品| 国产999精品久久久久久| 久久国产剧场电影| 九九九久久久精品| 91麻豆精品在线观看| 99精品国产视频| 日本福利一区二区| 欧美日韩mp4| 国产欧美精品一区二区色综合 | 亚洲天堂成人网| 中文字幕一区二区三区不卡| 中文字幕一区二区三| 一区二区三区日本| 五月天丁香久久| 777xxx欧美| 91.xcao| 中文字幕在线播放不卡一区| 18成人在线视频| 青椒成人免费视频| 国产福利一区在线| 56国语精品自产拍在线观看| 日韩欧美国产麻豆| 亚洲欧美激情小说另类| 九色|91porny| 欧美日韩一区二区三区视频| 久久婷婷国产综合精品青草| 亚洲欧美在线观看| 精品一区二区av| 欧美区一区二区三区| 亚洲三级在线观看| 国产iv一区二区三区| 91精品国产一区二区三区| 亚洲欧美一区二区在线观看| 国产一二三精品| 日韩欧美激情四射| 免费观看在线综合色| 欧美色电影在线| 一级日本不卡的影视| 国产iv一区二区三区| 久久精品水蜜桃av综合天堂| 激情深爱一区二区| 精品国产sm最大网站免费看| 日本免费新一区视频| 91麻豆精品国产自产在线观看一区 | 久久久精品天堂| 九九国产精品视频| 久久久久97国产精华液好用吗| 国产一区二区三区最好精华液| 日韩欧美卡一卡二| 成人精品高清在线| 亚洲在线成人精品| 欧美另类高清zo欧美| 精品午夜久久福利影院| 久久精品男人天堂av| 日本精品免费观看高清观看| 亚洲国产视频网站| 久久综合给合久久狠狠狠97色69| 国产激情一区二区三区桃花岛亚洲| 国产午夜亚洲精品羞羞网站| 99久久久国产精品| 美脚の诱脚舐め脚责91 | 国产麻豆欧美日韩一区| 国产精品国产自产拍高清av | 久久伊人蜜桃av一区二区| 成人精品视频一区二区三区尤物| 亚洲最大的成人av| 精品久久久久久久一区二区蜜臀| 成人av电影在线| 国产九色sp调教91| 青青草国产成人av片免费| 综合电影一区二区三区| 久久久久亚洲蜜桃| 欧美大片日本大片免费观看| 欧美三级三级三级| 成人动漫av在线| 东方欧美亚洲色图在线| 麻豆91精品视频| 日本午夜一本久久久综合| 亚洲伊人色欲综合网| 亚洲一区在线观看免费| 亚洲激情网站免费观看| 国产精品麻豆久久久| 精品国产乱码久久| 91麻豆精品国产91久久久久久久久| 国产乱码精品一品二品| 麻豆精品一区二区三区| 国产精品妹子av| 国产日韩欧美不卡| 久久人人爽爽爽人久久久|