[7963] Fixed energize value for 20186 proc.
[getmangos.git] / src / shared / Database / QueryResultMysql.cpp
blob9eb2dde4eba8caa55a2f0e8aa97da6cf74ee141f
1 /*
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
19 #ifndef DO_POSTGRESQL
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];
28 ASSERT(mCurrentRow);
30 for (uint32 i = 0; i < mFieldCount; i++)
31 mCurrentRow[i].SetType(ConvertNativeType(fields[i].type));
34 QueryResultMysql::~QueryResultMysql()
36 EndQuery();
39 bool QueryResultMysql::NextRow()
41 MYSQL_ROW row;
43 if (!mResult)
44 return false;
46 row = mysql_fetch_row(mResult);
47 if (!row)
49 EndQuery();
50 return false;
53 for (uint32 i = 0; i < mFieldCount; i++)
54 mCurrentRow[i].SetValue(row[i]);
56 return true;
59 void QueryResultMysql::EndQuery()
61 if (mCurrentRow)
63 delete [] mCurrentRow;
64 mCurrentRow = 0;
67 if (mResult)
69 mysql_free_result(mResult);
70 mResult = 0;
74 enum Field::DataTypes QueryResultMysql::ConvertNativeType(enum_field_types mysqlType) const
76 switch (mysqlType)
78 case FIELD_TYPE_TIMESTAMP:
79 case FIELD_TYPE_DATE:
80 case FIELD_TYPE_TIME:
81 case FIELD_TYPE_DATETIME:
82 case FIELD_TYPE_YEAR:
83 case FIELD_TYPE_STRING:
84 case FIELD_TYPE_VAR_STRING:
85 case FIELD_TYPE_BLOB:
86 case FIELD_TYPE_SET:
87 case FIELD_TYPE_NULL:
88 return Field::DB_TYPE_STRING;
89 case FIELD_TYPE_TINY:
91 case FIELD_TYPE_SHORT:
92 case FIELD_TYPE_LONG:
93 case FIELD_TYPE_INT24:
94 case FIELD_TYPE_LONGLONG:
95 case FIELD_TYPE_ENUM:
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;
101 default:
102 return Field::DB_TYPE_UNKNOWN;
105 #endif