Overview

Packages

  • Actions
  • Codegen
  • Controls
    • Base
  • DatabaseAdapters
  • Events
  • None
  • Sessions
  • Tests

Classes

  • AbstractControl_CodeGenerator
  • AjaxTimingForm
  • BasicForm
  • BasicOrmTests
  • BBCodeParser
  • CacheTests
  • CalculatorForm
  • CalculatorWidget
  • ComplexColumn
  • DataRepeaterExample
  • Event
  • ExampleCheckColumn1
  • ExampleCheckColumn2
  • ExampleForm
  • Examples
  • ExampleService
  • ExamplesForm
  • ExampleSingleForm
  • ExpandAsArrayTests
  • HtmlJqDoc
  • InjectForm
  • JavaScriptHelper
  • JqAttributes
  • JqControlGen
  • JqDoc
  • JqIcon
  • Method
  • ModelConnectorTests
  • MyControl
  • MyQSlider_ChangeEvent
  • NavPanel
  • NestedTabForm
  • Option
  • Order
  • PaginatorForm
  • ParamsForm
  • PersistentExampleForm
  • PersonEditPanel
  • PluginEditForm
  • PluginManagerForm
  • Project
  • ProjectEditPanel
  • ProjectListForm
  • ProjectPickerListBox
  • ProjectViewPanel
  • QAbstractCacheProvider
  • QAbstractHtmlTableColumn
  • QAbstractHtmlTableDataColumn
  • QAccordion
  • QAccordion_ActivateEvent
  • QAccordion_BeforeActivateEvent
  • QAccordion_CreateEvent
  • QAccordionBase
  • QAccordionGen
  • QAction
  • QActionControl
  • QAjaxAction
  • QAjaxControlAction
  • QAjaxResponse
  • QAlertAction
  • QApplication
  • QApplicationBase
  • QArchive
  • QAutocomplete
  • QAutocomplete_ChangeEvent
  • QAutocomplete_CloseEvent
  • QAutocomplete_CodeGenerator
  • QAutocomplete_CreateEvent
  • QAutocomplete_FocusEvent
  • QAutocomplete_OpenEvent
  • QAutocomplete_ResponseEvent
  • QAutocomplete_SearchEvent
  • QAutocomplete_SelectEvent
  • QAutocomplete_SourceEvent
  • QAutocompleteBase
  • QAutocompleteBase_CodeGenerator
  • QAutocompleteGen
  • QAutocompleteListItem
  • QBackspaceKeyEvent
  • QBaseClass
  • QBlockControl
  • QBlurControlAction
  • QBlurEvent
  • QBorderCollapse
  • QBorderStyle
  • QBrowserType
  • QButton
  • QButtonBase
  • QCache
  • QCacheDeleteAction
  • QCacheDeleteAllAction
  • QCacheProviderAPC
  • QCacheProviderLocalMemory
  • QCacheProviderLocalMemoryTest
  • QCacheProviderMemcache
  • QCacheProviderNoCache
  • QCacheProviderProxy
  • QCacheSetAction
  • QCalendar
  • QCalendarType
  • QCallType
  • QCausesValidation
  • QCellClickEvent
  • QChangeEvent
  • QCheckBox
  • QCheckBox_CodeGenerator
  • QCheckBoxBase_CodeGenerator
  • QCheckBoxLegacyColumn
  • QCheckBoxList
  • QCheckBoxList_CodeGenerator
  • QCheckBoxListBase_CodeGenerator
  • QClickEvent
  • QCodeGen
  • QCodeGenBase
  • QConfirmAction
  • QContextMenuEvent
  • QControl
  • QControl_CodeGenerator
  • QControlBase
  • QControlBase_CodeGenerator
  • QControlBaseTests
  • QControlCategoryType
  • QControlGrouping
  • QControlLabel
  • QControlProxy
  • QConvertNotation
  • QConvertNotationBase
  • QCrossScripting
  • QCryptography
  • QCss
  • QCssAction
  • QCssClassAction
  • QCssTests
  • QCsvTextBox
  • QCursor
  • QDatabaseBase
  • QDatabaseCodeGen
  • QDatabaseFieldBase
  • QDatabaseFieldType
  • QDatabaseForeignKey
  • QDatabaseIndex
  • QDatabaseResultBase
  • QDatabaseRowBase
  • QDatabaseTests
  • QDataGrid
  • QDataGrid_CheckBoxColumn
  • QDataGrid_CodeGenerator
  • QDataGrid_SortEvent
  • QDataGridBase
  • QDataGridBase_CodeGenerator
  • QDataGridLegacy
  • QDataGridLegacyBase
  • QDataGridLegacyColumn
  • QDataGridLegacyRow
  • QDataGridLegacyRowStyle
  • QDataRepeater
  • QDatepicker
  • QDatepicker_BeforeShowDayEvent
  • QDatepicker_BeforeShowEvent
  • QDatepicker_CalculateWeekEvent
  • QDatepicker_ChangeMonthYearEvent
  • QDatepicker_CloseEvent
  • QDatepicker_SelectEvent
  • QDatepicker_SelectEvent2
  • QDatepickerBase
  • QDatepickerBox
  • QDatepickerBox_BeforeShowDayEvent
  • QDatepickerBox_BeforeShowEvent
  • QDatepickerBox_CalculateWeekEvent
  • QDatepickerBox_ChangeMonthYearEvent
  • QDatepickerBox_CloseEvent
  • QDatepickerBox_CodeGenerator
  • QDatepickerBox_SelectEvent
  • QDatepickerBoxBase
  • QDatepickerBoxBase_CodeGenerator
  • QDatepickerBoxGen
  • QDatepickerGen
  • QDateTime
  • QDateTimePicker
  • QDateTimePicker_CodeGenerator
  • QDateTimePickerBase_CodeGenerator
  • QDateTimePickerFormat
  • QDateTimePickerType
  • QDateTimeSpan
  • QDateTimeTests
  • QDateTimeTextBox
  • QDbBackedFormStateHandler
  • QDbBackedSessionHandler
  • QDialog
  • QDialog_BeforeCloseEvent
  • QDialog_ButtonEvent
  • QDialog_CloseEvent
  • QDialog_CreateEvent
  • QDialog_DragEvent
  • QDialog_DragStartEvent
  • QDialog_DragStopEvent
  • QDialog_FocusEvent
  • QDialog_OpenEvent
  • QDialog_ResizeEvent
  • QDialog_ResizeStartEvent
  • QDialog_ResizeStopEvent
  • QDialogBase
  • QDialogBox
  • QDialogGen
  • QDisplayStyle
  • QDoubleClickEvent
  • QDownArrowKeyEvent
  • QDragDropEvent
  • QDraggable
  • QDraggable_CreateEvent
  • QDraggable_DragEvent
  • QDraggable_StartEvent
  • QDraggable_StopEvent
  • QDraggableBase
  • QDraggableGen
  • QDroppable
  • QDroppable_ActivateEvent
  • QDroppable_CreateEvent
  • QDroppable_DeactivateEvent
  • QDroppable_DropEvent
  • QDroppable_OutEvent
  • QDroppable_OverEvent
  • QDroppableBase
  • QDroppableGen
  • QDropZoneGrouping
  • QEmailAttachment
  • QEmailMessage
  • QEmailServer
  • QEmailStringAttachment
  • QEmailTextBox
  • QEnterKeyEvent
  • QErrorAttribute
  • QEscapeKeyEvent
  • QEvent
  • QFieldset
  • QFile
  • QFileAsset
  • QFileAssetBase
  • QFileAssetDialog
  • QFileAssetType
  • QFileControl
  • QFileFormStateHandler
  • QFilterType
  • QFloatTextBox
  • QFloatTextBox_CodeGenerator
  • QFloatTextBoxBase_CodeGenerator
  • QFocusControlAction
  • QFocusEvent
  • QFocusInEvent
  • QFocusOutEvent
  • QFolder
  • QFontFamily
  • QForm
  • QFormBase
  • QFormGen
  • QFormStateHandler
  • QGridLines
  • QHideCalendarAction
  • QHideDialog
  • QHideDialogBox
  • QHListControl
  • QHListItem
  • QHorizontalAlign
  • QHtml
  • QHtmlAttributeManager
  • QHtmlAttributeManagerBase
  • QHtmlReporter
  • QHtmlTable
  • QHtmlTable_CodeGenerator
  • QHtmlTableBase
  • QHtmlTableCallableColumn
  • QHtmlTableCheckBoxColumn
  • QHtmlTableCheckBoxColumn_ClickEvent
  • QHtmlTableIndexedColumn
  • QHtmlTableLinkColumn
  • QHtmlTableNodeColumn
  • QHtmlTablePropertyColumn
  • QI18n
  • QI18nTests
  • QImageBase
  • QImageBrowser
  • QImageBrowserBase
  • QImageBrowserNav
  • QImageBrowserThumbnails
  • QImageButton
  • QImageControl
  • QImageControlBase
  • QImageFileAsset
  • QImageLabel
  • QImageLabelBase
  • QImageRollover
  • QImageType
  • QIndex
  • QInformixPdoDatabase
  • QInformixPdoDatabaseField
  • QInformixPdoDatabaseResult
  • QInformixPdoDatabaseRow
  • QInputEvent
  • QInstallationValidationResult
  • QInstallationValidator
  • QIntegerTextBox
  • QIntegerTextBox_CodeGenerator
  • QIntegerTextBoxBase_CodeGenerator
  • QJavaScriptAction
  • QJQAction
  • QJQBounceAction
  • QJqButton
  • QJqButton_CreateEvent
  • QJqButtonBase
  • QJqButtonGen
  • QJqCheckBox
  • QJqCheckBox_CreateEvent
  • QJqCheckBoxBase
  • QJqCheckBoxGen
  • QJQHideAction
  • QJQHideEffectAction
  • QJQHighlightAction
  • QJQPulsateAction
  • QJqRadioButton
  • QJqRadioButton_CreateEvent
  • QJqRadioButtonBase
  • QJqRadioButtonGen
  • QJQShakeAction
  • QJQShowAction
  • QJQShowEffectAction
  • QJQSizeAction
  • QJQToggleAction
  • QJQToggleEffectAction
  • QJQTransferAction
  • QJqUiEvent
  • QJqUiPropertyEvent
  • QJsClosure
  • QJsFunction
  • QJsNoQuoteKey
  • QJsParameterList
  • QJsPriority
  • QJsTimer
  • QJsTimerBase
  • QJsVarName
  • QKeyDownEvent
  • QKeyPressEvent
  • QKeyUpEvent
  • QLabel
  • QLabel_CodeGenerator
  • QLabelBase_CodeGenerator
  • QLexer
  • QLinkButton
  • QListBox
  • QListBox_CodeGenerator
  • QListBoxBase
  • QListBoxBase_CodeGenerator
  • QListControl
  • QListControl_CodeGenerator
  • QListControlBase_CodeGenerator
  • QListItem
  • QListItemBase
  • QListItemStyle
  • QManyToManyReference
  • QMenu
  • QMenu_BlurEvent
  • QMenu_CreateEvent
  • QMenu_FocusEvent
  • QMenu_SelectEvent
  • QMenuBase
  • QMenuGen
  • QMimeType
  • QModelConnectorArgumentType
  • QModelConnectorCreateType
  • QModelConnectorEditDlg
  • QModelConnectorOptions
  • QModelConnectorParam
  • QMouseDownEvent
  • QMouseEnterEvent
  • QMouseLeaveEvent
  • QMouseMoveEvent
  • QMouseOutEvent
  • QMouseOverEvent
  • QMouseUpEvent
  • QMultiLevelCacheProvider
  • QMySqlDatabase
  • QMySqlDatabaseField
  • QMySqlDatabaseResult
  • QMySqli5ClusterDatabase
  • QMySqli5Database
  • QMySqli5DatabaseField
  • QMySqli5DatabaseResult
  • QMySqliDatabase
  • QMySqliDatabaseField
  • QMySqliDatabaseResult
  • QMySqliDatabaseRow
  • QNoScriptAjaxAction
  • QNumericTextBox
  • QOnEvent
  • QOracleDatabase
  • QOracleDatabaseField
  • QOracleDatabaseResult
  • QOracleDatabaseRow
  • QOrderedListType
  • QOverflow
  • QPaginatedControl
  • QPaginator
  • QPaginatorBase
  • QPanel
  • QPartialQueryBuilder
  • QPdoDatabase
  • QPdoDatabaseResult
  • QPgConditionILike
  • QPgConditionJsonContains
  • QPgQ
  • QPosition
  • QPostgreSqlDatabase
  • QPostgreSqlDatabaseField
  • QPostgreSqlDatabaseResult
  • QPostgreSqlDatabaseRow
  • QPostgreSqlPdoDatabase
  • QPostgreSqlPdoDatabaseField
  • QPostgreSqlPdoDatabaseResult
  • QPostgreSqlPdoDatabaseRow
  • QProgressbar
  • QProgressbar_ChangeEvent
  • QProgressbar_CompleteEvent
  • QProgressbar_CreateEvent
  • QProgressbarBase
  • QProgressbarGen
  • QQ
  • QQAggregationClause
  • QQAliasTests
  • QQAssociationNode
  • QQAverage
  • QQClause
  • QQColumnNode
  • QQCondition
  • QQConditionAll
  • QQConditionAnd
  • QQConditionBetween
  • QQConditionComparison
  • QQConditionEqual
  • QQConditionExists
  • QQConditionGreaterOrEqual
  • QQConditionGreaterThan
  • QQConditionIn
  • QQConditionIsNotNull
  • QQConditionIsNull
  • QQConditionLessOrEqual
  • QQConditionLessThan
  • QQConditionLike
  • QQConditionLogical
  • QQConditionNone
  • QQConditionNot
  • QQConditionNotBetween
  • QQConditionNotEqual
  • QQConditionNotExists
  • QQConditionNotIn
  • QQConditionNotLike
  • QQConditionOr
  • QQCount
  • QQDistinct
  • QQExpand
  • QQExpandAsArray
  • QQExpandVirtualNode
  • QQFuncTests
  • QQFunctionNode
  • QQGroupBy
  • QQHavingClause
  • QQLimitInfo
  • QQMathNode
  • QQMathOpTests
  • QQMaximum
  • QQMinimum
  • QQNamedValue
  • QQNode
  • QQNoParentNode
  • QQOrderBy
  • QQReverseReferenceNode
  • QQSelect
  • QQSubQueryCountNode
  • QQSubQueryNode
  • QQSubQuerySqlNode
  • QQSum
  • QQTableNode
  • QQuery
  • QQueryBuilder
  • QQueryExpansion
  • QQVirtualNode
  • QRadioButton
  • QRadioButtonList
  • QRadioButtonList_CodeGenerator
  • QRadioButtonListBase_CodeGenerator
  • QRedirectAction
  • QReference
  • QRegex
  • QRegisterClickPositionAction
  • QRepeatDirection
  • QRequestMode
  • QResetTimerAction
  • QResizable
  • QResizable_CreateEvent
  • QResizable_ResizeEvent
  • QResizable_StartEvent
  • QResizable_StopEvent
  • QResizableBase
  • QResizableGen
  • QResizeHandleDirection
  • QRestServiceCodeGen
  • QReverseReference
  • QRssCategory
  • QRssFeed
  • QRssImage
  • QRssItem
  • QSampleControl
  • QSampleTranslation
  • QSelectable
  • QSelectable_CreateEvent
  • QSelectable_SelectedEvent
  • QSelectable_SelectingEvent
  • QSelectable_StartEvent
  • QSelectable_StopEvent
  • QSelectable_UnselectedEvent
  • QSelectable_UnselectingEvent
  • QSelectableBase
  • QSelectableGen
  • QSelectControlAction
  • QSelectEvent
  • QSelectionMode
  • QSelectMenu
  • QSelectMenu_ChangeEvent
  • QSelectMenu_CloseEvent
  • QSelectMenu_CreateEvent
  • QSelectMenu_FocusEvent
  • QSelectMenu_OpenEvent
  • QSelectMenu_SelectEvent
  • QSelectMenuBase
  • QSelectMenuGen
  • QServerAction
  • QServerControlAction
  • QSessionFormStateHandler
  • QSetValueAction
  • QShowCalendarAction
  • QShowDialog
  • QShowDialogBox
  • QSlider
  • QSlider_ChangeEvent
  • QSlider_CodeGenerator
  • QSlider_CreateEvent
  • QSlider_SlideEvent
  • QSlider_StartEvent
  • QSlider_StopEvent
  • QSliderBase
  • QSliderBase_CodeGenerator
  • QSliderGen
  • QSoapMethod
  • QSoapParameter
  • QSoapService
  • QSortable
  • QSortable_ActivateEvent
  • QSortable_BeforeStopEvent
  • QSortable_ChangeEvent
  • QSortable_CreateEvent
  • QSortable_DeactivateEvent
  • QSortable_OutEvent
  • QSortable_OverEvent
  • QSortable_ReceiveEvent
  • QSortable_RemoveEvent
  • QSortable_SortEvent
  • QSortable_StartEvent
  • QSortable_StopEvent
  • QSortable_UpdateEvent
  • QSortableBase
  • QSortableGen
  • QSpinner
  • QSpinner_ChangeEvent
  • QSpinner_CreateEvent
  • QSpinner_SpinEvent
  • QSpinner_StartEvent
  • QSpinner_StopEvent
  • QSpinnerBase
  • QSpinnerGen
  • QSqlColumn
  • QSqLite3PdoDatabase
  • QSqLite3PdoDatabaseField
  • QSqLite3PdoDatabaseResult
  • QSqLite3PdoDatabaseRow
  • QSqlServer2005Database
  • QSqlServer2005DatabaseField
  • QSqlServer2005DatabaseResult
  • QSqlServer2005DatabaseRow
  • QSqlServerDatabase
  • QSqlServerDatabaseField
  • QSqlServerDatabaseResult
  • QSqlServerDatabaseRow
  • QSqlTable
  • QStack
  • QStopPropagationAction
  • QString
  • QStringTest
  • QTabKeyEvent
  • QTabs
  • QTabs_ActivateEvent
  • QTabs_BeforeActivateEvent
  • QTabs_BeforeLoadEvent
  • QTabs_CreateEvent
  • QTabs_LoadEvent
  • QTabsBase
  • QTabsGen
  • QTag
  • QTagStyler
  • QTerminateAction
  • QTestControl
  • QTestForm
  • QTextAlign
  • QTextBox
  • QTextBox_CodeGenerator
  • QTextBoxBase
  • QTextBoxBase_CodeGenerator
  • QTextMode
  • QTimer
  • QTimerExpiredEvent
  • QTimerTests
  • QToggleCssClassAction
  • QToggleDisplayAction
  • QToggleEnableAction
  • QTranslationPoParser
  • QTreeNav
  • QTreeNavItem
  • QType
  • QTypeTable
  • QTypeTests
  • QUnitTestCaseBase
  • QUnorderedListStyle
  • QUpArrowKeyEvent
  • QUrlTextBox
  • QVerticalAlign
  • QVirtualAttributeColumn
  • QWaitIcon
  • QWatcher
  • QWatcherBase
  • QWatcherCache
  • QWatcherDB
  • QWatcherNone
  • QWriteBox
  • RecordsSummary
  • RefreshForm
  • SampleComposite
  • SampleForm
  • SelectableLabel
  • SelectForm
  • SpeedForm
  • TestImageBrowser
  • UrlForm

Interfaces

  • ICacheAction
  • QDataList_CodeGenerator_Interface
  • QTranslationBase

Traits

  • QDataBinder
  • QListItemManager
  • QModelTrait

Exceptions

  • QCallerException
  • QCrossScriptingException
  • QCryptographyException
  • QDatabaseExceptionBase
  • QDataBindException
  • QDateTimeNullException
  • QEmailException
  • QIndexOutOfRangeException
  • QInformixPdoDatabaseException
  • QInvalidCastException
  • QInvalidFormStateException
  • QMySqliDatabaseException
  • QOptimisticLockingException
  • QOracleDatabaseException
  • QPdoDatabaseException
  • QPoParserException
  • QPostgreSqlDatabaseException
  • QPostgreSqlPdoDatabaseException
  • QRemoteAdminDeniedException
  • QSqLite3PdoDatabaseException
  • QSqlServer2005DatabaseException
  • QSqlServerDatabaseException
  • QUndefinedMethodException
  • QUndefinedPrimaryKeyException
  • QUndefinedPropertyException

Functions

  • __database_check_error
  • __QForm_EvaluateTemplate_ObHandler
  • _b
  • _indent
  • _nl
  • _p
  • _r
  • _t
  • _tp
  • _tr
  • array_trim
  • beginsWith
  • CamelCaseFromDash
  • CastToInt
  • DataGridEvalHandleError
  • DisplayMonospacedText
  • endsWith
  • GO_BACK
  • jq_anytime_gen
  • jq_control_gen
  • jq_inc_gen
  • jq_indent
  • PrintExplainStatement
  • PrintInstructions
  • QcubedHandleCodeGenParseError
  • QcubedHandleError
  • QcubedHandleException
  • QCubedShutdown
  • QDateTimeErrorHandler
  • trimOffEnd
  • trimOffFront
  • Overview
  • Package
  • Class
  1: <?php
  2:     // This Database Adapter depends on MySqliDatabase
  3:     if (!class_exists('QMySqliDatabase'))
  4:         require(__QCUBED_CORE__ . '/database/QMySqliDatabase.class.php');
  5: 
  6:     /**
  7:      *
  8:      * @package DatabaseAdapters
  9:      */
 10:     class QMySqlDatabase extends QMySqliDatabase {
 11:         const Adapter = 'MySql Legacy Database Adapter for MySQL 4';
 12: 
 13:         protected $objDb;
 14: 
 15:         public function Connect() {
 16:             // Lookup Adapter-Specific Connection Properties
 17:             $strServer = $this->Server;
 18:             $strName = $this->Database;
 19:             $strUsername = $this->Username;
 20:             $strPassword = $this->Password;
 21:             $strPort = $this->Port;
 22: 
 23:             if ($strPort)
 24:                 $strServer .= ':' . $strPort;
 25: 
 26:             // Connect to the Database Server
 27:             $this->objDb = mysql_connect($strServer, $strUsername, $strPassword, true);
 28:             if (!$this->objDb)
 29:                 throw new QMySqliDatabaseException("Unable to connect to Database Server: $strServer", -1, null);
 30:             if (mysql_errno($this->objDb))
 31:                 throw new QMySqliDatabaseException(mysql_error($this->objDb), mysql_errno($this->objDb), null);
 32: 
 33:             // Select the DB
 34:             if (!mysql_select_db($strName, $this->objDb))
 35:                 throw new QMySqliDatabaseException("Unable to select the Database: $strName", -1, null);
 36:             if (mysql_errno($this->objDb))
 37:                 throw new QMySqliDatabaseException(mysql_error($this->objDb), mysql_errno($this->objDb), null);
 38: 
 39:             // Update "Connected" Flag
 40:             $this->blnConnectedFlag = true;
 41: 
 42:             // Set to AutoCommit
 43:             $this->NonQuery('SET AUTOCOMMIT=1;');
 44: 
 45:             // Set NAMES (if applicable)
 46:             if (array_key_exists('encoding', $this->objConfigArray))
 47:                 $this->NonQuery('SET NAMES ' . $this->objConfigArray['encoding'] . ';');
 48:         }
 49: 
 50:         public function __get($strName) {
 51:             switch ($strName) {
 52:                 case 'AffectedRows':
 53:                     return mysql_affected_rows($this->objDb);
 54:                 default:
 55:                     try {
 56:                         return parent::__get($strName);
 57:                     } catch (QCallerException $objExc) {
 58:                         $objExc->IncrementOffset();
 59:                         throw $objExc;
 60:                     }
 61:             }
 62:         }
 63: 
 64:         protected function ExecuteQuery($strQuery) {
 65:             // Perform the Query
 66:             $objResult = mysql_query($strQuery, $this->objDb);          
 67:             if (mysql_errno($this->objDb))
 68:                 throw new QMySqliDatabaseException(mysql_error($this->objDb), mysql_errno($this->objDb), $strQuery);
 69: 
 70:             // Return the Result
 71:             $objMySqlDatabaseResult = new QMySqlDatabaseResult($objResult, $this);
 72:             return $objMySqlDatabaseResult;
 73:         }
 74: 
 75:         protected function ExecuteNonQuery($strNonQuery) {
 76:             // Perform the Query
 77:             mysql_query($strNonQuery, $this->objDb);
 78:             if (mysql_errno($this->objDb))
 79:                 throw new QMySqliDatabaseException(mysql_error($this->objDb), mysql_errno($this->objDb), $strNonQuery);
 80:         }
 81: 
 82:         public function InsertId($strTableName = null, $strColumnName = null) {
 83:             $result = $this->Query('SELECT LAST_INSERT_ID();');
 84:             $data = $result->FetchArray();
 85:             $result->Close();
 86:             return $data[0];
 87:         }
 88: 
 89:         public function Close() {
 90:             mysql_close($this->objDb);
 91: 
 92:             // Update Connected Flag
 93:             $this->blnConnectedFlag = false;
 94:         }
 95: 
 96:         public function GetFieldsForTable($strTableName) {
 97:             $objResult = new QMySqlDatabaseResult(mysql_list_fields($this->Database, $strTableName, $this->objDb), $this);
 98:             return $objResult->FetchFields();
 99:         }
100:     }
101: 
102:     /**
103:      * Class to handle results sent by database upon querying
104:      */
105:     class QMySqlDatabaseResult extends QMySqliDatabaseResult {
106:         protected $objMySqlResult;
107:         protected $objDb;
108: 
109:         public function __construct($objResult, QMySqlDatabase $objDb) {
110:             $this->objMySqlResult = $objResult;
111:             $this->objDb = $objDb;
112:         }
113: 
114:         public function FetchArray() {
115:             return mysql_fetch_array($this->objMySqlResult);
116:         }
117: 
118:         public function FetchFields() {
119:             $objArrayToReturn = array();
120:             while ($objField = mysql_fetch_field($this->objMySqlResult)) {
121:                 array_push($objArrayToReturn, new QMySqlDatabaseField($objField, $this->objDb));
122:             }
123:             return $objArrayToReturn;
124:         }
125: 
126:         public function FetchField() {
127:             if ($objField = mysql_fetch_field($this->objMySqlResult))
128:                 return new QMySqlDatabaseField($objField, $this->objDb);
129:         }
130: 
131:         public function FetchRow() {
132:             return mysql_fetch_row($this->objMySqlResult);
133:         }
134:         
135:         public function MySqlFetchField() {
136:             return mysql_fetch_field($this->objMySqlResult);
137:         }
138: 
139:         public function CountRows() {
140:             return mysql_num_rows($this->objMySqlResult);
141:         }
142: 
143:         public function CountFields() {
144:             return mysql_num_fields($this->objMySqlResult);
145:         }
146: 
147:         public function Close() {
148:             mysql_free_result($this->objMySqlResult);
149:         }
150:     }
151:     
152:     /**
153:      *
154:      * @package DatabaseAdapters
155:      */
156:     class QMySqlDatabaseField extends QMySqliDatabaseField {
157:         public function __construct($mixFieldData, $objDb = null) {
158:             $this->strName = $mixFieldData->name;
159:             $this->strOriginalName = $this->strName;
160:             $this->strTable = $mixFieldData->table;
161:             $this->strOriginalTable = $mixFieldData->table;
162:             $this->strDefault = $mixFieldData->def;
163:             $this->intMaxLength = null;
164:             $this->strComment = null;
165: 
166:             // Calculate MaxLength of this column (e.g. if it's a varchar, calculate length of varchar
167:             // Also, see if it's auto increment
168:             if ($this->strOriginalTable) {
169:                 try {
170:                   $objDescriptionResult = $objDb->Query(sprintf("SHOW FULL FIELDS FROM `%s`", $this->strOriginalTable));
171:                   while (($objRow = $objDescriptionResult->FetchArray())) {
172:                     if ($objRow["Field"] == $this->strOriginalName) {
173:                       if ($objRow["Extra"] == 'auto_increment')
174:                         $this->blnIdentity = true;
175:                       else
176:                         $this->blnIdentity = false;
177:                     
178:                       $this->strComment = $objRow["Comment"];
179:                       $strLengthArray = explode("(", $objRow["Type"]);
180:                       if ((count($strLengthArray) > 1) &&
181:                         (strtolower($strLengthArray[0]) != 'enum') &&
182:                         (strtolower($strLengthArray[0]) != 'set')) {
183:                         $strLengthArray = explode(")", $strLengthArray[1]);
184:                         $this->intMaxLength = $strLengthArray[0];
185:             
186:                         // If the length is something like (7,2), then let's pull out just the "7"
187:                         $intCommaPosition = strpos($this->intMaxLength, ',');
188:                         if ($intCommaPosition !== false) {
189:                             $this->intMaxLength = substr($this->intMaxLength, 0, $intCommaPosition);
190:                             $this->intMaxLength++; // make room for decimal point
191:                         }
192: 
193:                         if (!is_numeric($this->intMaxLength))
194:                           throw new Exception("Not a valid Column Length: " . $objRow["Type"]);         
195:                       }
196:                     }
197:                   }
198:                 }
199:                 catch(Exception $e) {
200:                   // Do Nothing
201:                 }
202:             }
203: 
204:             $this->blnNotNull = QType::Cast($mixFieldData->not_null, QType::Boolean);
205:             $this->blnPrimaryKey = QType::Cast($mixFieldData->primary_key, QType::Boolean);
206:             $this->blnUnique = QType::Cast($mixFieldData->unique_key, QType::Boolean);
207: 
208:             switch ($mixFieldData->type) {
209:                 case 'int':
210:                     if ($this->intMaxLength == 1)
211:                         $this->strType = QDatabaseFieldType::Bit;
212:                     else
213:                         $this->strType = QDatabaseFieldType::Integer;
214:                     break;
215:                 case 'real':
216:                 case 'float':
217:                     $this->strType = QDatabaseFieldType::Float;
218:                     break;
219:                 case 'double':
220:                     // NOTE: PHP does not offer full support of double-precision floats.
221:                     // Value will be set as a VarChar which will guarantee that the precision will be maintained.
222:                     //    However, you will not be able to support full typing control (e.g. you would
223:                     //    not be able to use a QFloatTextBox -- only a regular QTextBox)
224:                     $this->strType = QDatabaseFieldType::VarChar;
225:                     break;
226:                 case 'timestamp':
227:                     // System-generated Timestamp values need to be treated as plain text
228:                     $this->strType = QDatabaseFieldType::VarChar;
229:                     $this->blnTimestamp = true;
230:                     break;
231:                 case 'date':
232:                     $this->strType = QDatabaseFieldType::Date;
233:                     break;
234:                 case 'time':
235:                     $this->strType = QDatabaseFieldType::Time;
236:                     break;
237:                 case 'datetime':
238:                     $this->strType = QDatabaseFieldType::DateTime;
239:                     break;
240:                 case 'blob':
241:                     $this->strType = QDatabaseFieldType::Blob;
242:                     break;
243:                 case 'string':
244:                     $this->strType = QDatabaseFieldType::VarChar;
245:                     break;
246:                 case 'char':
247:                     $this->strType = QDatabaseFieldType::Char;
248:                     break;
249:                 case 'json':    // >= MySQL v5.7
250:                     $this->strType = QDatabaseFieldType::Json;
251:                     break;
252:                 default:
253:                     throw new Exception("Unable to determine MySqli Database Field Type: " . $mixFieldData->type);
254:                     break;
255:             }
256:         }
257:     }
258: 
API documentation generated by ApiGen