Подтвердить что ты не робот

DataRow обнуляет десятичную часть десятичного числа при обновлении Datatable

Я пытаюсь обновить DataTable, который извлекается из БД, прежде чем привязывать его к Gridview.

Однако, когда я обновляю десятичные поля, часть после десятичной точки обнуляется. Что мне не хватает?

if (HttpContext.Current.Request.IsAuthenticated)
{
    // Get additional price matches
    using (SqlConnection stockConn = new SqlConnection(ConfigurationManager.ConnectionStrings["LocalSqlServer"].ConnectionString))
    {
        // Check for trade match offer
        SqlCommand tradePCCheck = new SqlCommand("getAllMyPriceMatches", stockConn);
        tradePCCheck.CommandType = CommandType.StoredProcedure;
        SqlParameter email = tradePCCheck.Parameters.Add("@email", SqlDbType.NVarChar);
        try
        {
            email.Value = this.Context.User.Identity.Name;
        }
        catch
        {
            email.Value = " ";
        }
        SqlParameter thedate = tradePCCheck.Parameters.Add("@theDate", SqlDbType.DateTime);
        thedate.Value = DateTime.Now.AddHours(-50);

        stockConn.Open();
        SqlDataReader pcReader = tradePCCheck.ExecuteReader();
        pms.Load(pcReader);
        pcReader.Close();
        stockConn.Close();
    }
}

//Set Connection, Open the DB & Fill Data Set

using (SqlConnection stockConn = new SqlConnection(ConfigurationManager.ConnectionStrings["LocalSqlServer"].ConnectionString))
{
    SqlCommand stockCommand = new SqlCommand("getTISearchResults", stockConn);
    stockCommand.CommandType = CommandType.StoredProcedure;
    SqlParameter keyword = stockCommand.Parameters.Add("@keyword", SqlDbType.NVarChar);
    keyword.Value = prefixText;
    stockConn.Open();
    SqlDataReader rd = stockCommand.ExecuteReader();
    searchResults.Load(rd);
    stockCommand.Dispose();
    rd.Dispose();
}

// Update Results with elevated prices...
foreach (DataRow dr in searchResults.Rows)
{
    // Check for PMS
    DataRow[] thePMS = pms.Select("tpc_stockid = '" + dr["stockitem_number"].ToString() + "'");

    if (thePMS.Length > 0)
    {
        decimal px = 0;
        decimal cash = 0;

        if (thePMS[0]["tpc_pricepx"] != null && !thePMS[0]["tpc_pricepx"].ToString().Equals(""))
        {
            px = Convert.ToDecimal(thePMS[0]["tpc_pricepx"]);
        }

        if (thePMS[0]["tpc_price"] != null && !thePMS[0]["tpc_price"].ToString().Equals(""))
        {
            cash = Convert.ToDecimal(thePMS[0]["tpc_price"]);
        }
        // update table and accept changes
        DataRow[] theRows = searchResults.Select("stockitem_number = '" + dr["stockitem_number"].ToString() + "' ");

        if (theRows.Length > 0)
        {
            theRows[0]["stockitem_pxprice"] = px;
            theRows[0]["stockitem_cashprice"] = cash;
            searchResults.AcceptChanges();
        }
    }
}

gvSearchResults.DataSource = searchResults;
gvSearchResults.DataBind();

У меня есть вывод PX и Cash перед назначением, и они содержат правильные значения 800.19 и 500.12, но после AcceptChanges и после их привязки выход составляет 800.00 и 500.12.

theRows[0]["stockitem_pxprice"] и theRows[0]["stockitem_cashprice"] являются как decimal(5,2) в БД, где searchResultsDT заполняется из.

Любая помощь очень ценится.

Спасибо.

4b9b3361

Ответ 1

Да, вам не хватает string.format при установке значения в сетку. Перед настройкой вам нужно форматировать double.

Скажем, если вы получите число, например 4.506, оно отобразит что-то вроде 4.5060, или если у вас есть число, например 4.5, то оно будет отображаться как 4.50.

Я столкнулся с этой проблемой в шаблоном gridview и должен был использовать спецификатор string.format и format для его разрешения.

Ответ 2

Я думаю, что ваша таблица имеет ниже двух полей как тип данных int:

  • stockitem_pxprice

  • stockitem_cashprice

измените таблицу с типом данных как numeric (18,2) для этих двух полей

или

измените таблицу с типом данных как [decimal](18, 2) для этих двух полей

нет необходимости в typecasting, asp.net сделает это неявно

Ответ 3

Предварителю theRows.Columns и дайте свойство .Type для отслеживания. Вы упомянули несколько раз, что тип десятичный (5,2), который является типом TSQL. DataTable содержит типы С#, которые являются десятичными и похожими на очень большой поплавок. Это имеет значение тип С#.

Возможно, в вашем tsql было преобразование, например. Select myVal * 1, который превращает ваш десятичный знак myVal в int. Тогда это будет тип, который ваш datatable держит. Я обычно устанавливаю свои константы как-то вроде myVal *1.0, чтобы предотвратить превращение значений в int. Так же, как вы должны объявить десятичное число в С#, таком как 100 м, в TSQL вы должны убедиться, что литералы объявлены специально для предотвращения преобразований типа данных

Ref http://msdn.microsoft.com/en-us/library/ms179899.aspx

Ответ 4

Я не уверен, что у вас еще есть ответ, но я бы поделился тем, что смог исправить это, используя метод SqlDataReader, это GetDecimal. Вы могли бы написать код

using (SqlConnection stockConn = new SqlConnection(ConfigurationManager.ConnectionStrings["LocalSqlServer"].ConnectionString))
{
        // Check for trade match offer
        SqlCommand tradePCCheck = new SqlCommand("getAllMyPriceMatches", stockConn);
        tradePCCheck.CommandType = CommandType.StoredProcedure;
        SqlParameter email = tradePCCheck.Parameters.Add("@email", SqlDbType.NVarChar);
        try
        {
            email.Value = this.Context.User.Identity.Name;
        }
        catch
        {
            email.Value = " ";
        }
        SqlParameter thedate = tradePCCheck.Parameters.Add("@theDate", SqlDbType.DateTime);
        thedate.Value = DateTime.Now.AddHours(-50);

        stockConn.Open();

    SqlDataReader pcReader = tradePCCheck.ExecuteReader();

    decimal px = 0;
    decimal cash = 0;

    if (pcReader.Read())
    {
        px = pcReader.GetDecimal(0);
        cash = pcReader.GetDecimal(1);
    }
    pcReader.Close();
    stockConn.Close();
}

Где pcReader.GetDecimal(0) означает получить поле данных с индексом 0 как десятичное значение из набора результатов, это порядок выбранных столбцов в команде SELECT. И хранимая процедура getAllMyPriceMatches, вы можете изменить запрос script с помощью команды JOIN, между двумя результатами таблицы, тогда вам не нужно иметь вторую область запроса,