2 * Copyright (C) 2005-2009 MaNGOS <http://getmangos.com/>
4 * This program is free software; you can redistribute it and/or modify
5 * it under the terms of the GNU General Public License as published by
6 * the Free Software Foundation; either version 2 of the License, or
7 * (at your option) any later version.
9 * This program is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 * GNU General Public License for more details.
14 * You should have received a copy of the GNU General Public License
15 * along with this program; if not, write to the Free Software
16 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
21 #include "DatabaseEnv.h"
23 QueryResultMysql::QueryResultMysql(MYSQL_RES
*result
, MYSQL_FIELD
*fields
, uint64 rowCount
, uint32 fieldCount
) :
24 QueryResult(rowCount
, fieldCount
), mResult(result
)
27 mCurrentRow
= new Field
[mFieldCount
];
30 for (uint32 i
= 0; i
< mFieldCount
; i
++)
31 mCurrentRow
[i
].SetType(ConvertNativeType(fields
[i
].type
));
34 QueryResultMysql::~QueryResultMysql()
39 bool QueryResultMysql::NextRow()
46 row
= mysql_fetch_row(mResult
);
53 for (uint32 i
= 0; i
< mFieldCount
; i
++)
54 mCurrentRow
[i
].SetValue(row
[i
]);
59 void QueryResultMysql::EndQuery()
63 delete [] mCurrentRow
;
69 mysql_free_result(mResult
);
74 enum Field::DataTypes
QueryResultMysql::ConvertNativeType(enum_field_types mysqlType
) const
78 case FIELD_TYPE_TIMESTAMP
:
81 case FIELD_TYPE_DATETIME
:
83 case FIELD_TYPE_STRING
:
84 case FIELD_TYPE_VAR_STRING
:
88 return Field::DB_TYPE_STRING
;
91 case FIELD_TYPE_SHORT
:
93 case FIELD_TYPE_INT24
:
94 case FIELD_TYPE_LONGLONG
:
96 return Field::DB_TYPE_INTEGER
;
97 case FIELD_TYPE_DECIMAL
:
98 case FIELD_TYPE_FLOAT
:
99 case FIELD_TYPE_DOUBLE
:
100 return Field::DB_TYPE_FLOAT
;
102 return Field::DB_TYPE_UNKNOWN
;