Получение ошибки переполнения при выполнении запроса pl/sql
Когда я запускаю запрос pl/sql [через хранимую процедуру], используя мой код С#, я получаю сообщение об ошибке:
Как мне решить то же самое? Просьба сообщить.
Примечание: я передаю false для идентификаторов providerSpecificTypes в коде.
Error Message:
System.Data.OracleClient.OracleException: OCI-22053: overflow error
at System.Data.Common.DbDataAdapter.FillErrorHandler(Exception e, DataTable dataTable, Object[] dataValues)
at System.Data.Common.DbDataAdapter.FillLoadDataRowChunk(SchemaMapping mapping, Int32 startRecord, Int32 maxRecords)
at System.Data.Common.DbDataAdapter.FillFromReader(Object data, String srcTable, IDataReader dataReader, Int32 startRecord, Int32 maxRecords, DataColumn parentChapterColumn, Object parentChapterValue)
at System.Data.Common.DbDataAdapter.Fill(DataSet dataSet, String srcTable, IDataReader dataReader, Int32 startRecord, Int32 maxRecords)
at System.Data.Common.DbDataAdapter.FillFromCommand(Object data, Int32 startRecord, Int32 maxRecords, String srcTable, IDbCommand command, CommandBehavior behavior)
at System.Data.Common.DbDataAdapter.Fill(DataSet dataSet, Int32 startRecord, Int32 maxRecords, String srcTable, IDbCommand command,
Вот код:
DataSet ds = new DataSet();
try
{
this.OpenDBConnection();
this.dbAdapter.ReturnProviderSpecificTypes = providerSpecificTypes;
this.dbAdapter.Fill(ds);
}
catch
{
throw;
}
finally
{
CloseDBConnection();
this.cmd.Parameters.Clear();
}
return ds;
Query:
SELECT client_id, TO_CHAR (business_dt, 'MM/DD/YYYY') AS business_dt
, mkt_type
, mkt_name
, product_name
, period
, TO_CHAR (start_dt, 'MM/DD/YYYY') AS start_dt
, TO_CHAR (end_dt, 'MM/DD/YYYY') AS end_dt
, duration
, term
, NULL AS strike_price
, instrument_type
, final_price
, NULL AS product_price
, units
, NULL AS expiry_dt
, mkt_close
, cons_flag
Ответы
Ответ 1
Одно из выбранных значений столбца имеет точность, превышающую десятичный тип .Net. Лучшим способом решения этой проблемы является РАССЫЛКА значений столбца для управляемого размера предвидения. Обычно я округлю их до двух цифр десятичной точки, так как мне не нужно больше, чем это, вы можете выбрать в соответствии с вашими потребностями.
Итак, измените свой запрос так, чтобы все столбцы с более высоким номером точности округлялись до нужного числа десятичных знаков:
Пример:
Select ROUND(final_price, 2) From <your table>
должен решить вашу проблему.