gpt4 book ai didi

c# - 从数值数据类型转换为十进制时出错

转载 作者:行者123 更新时间:2023-12-01 16:48:50 25 4
gpt4 key购买 nike

这是我的问题,我有一个包含以下列的表:

asis_doc_minutos decimal(4,1)

如果我使用简单的插入查询插入以下数字(1.5),它就会插入它!但我的 SProcedure 不插入数据。这是我的 Sp:

 ALTER procedure [dbo].[insertar_pla_asis_doc]
@fecha datetime,
@tema varchar(500),
@minutos decimal(2,2),
@cod_docente int,
@cod_materia varchar(25),
@cod_seccion int,
@cod_ciclo int,
@cod_escuela int
as
begin
insert into pla_asis_doc(asis_doc_fecha, asis_doc_tema,
asis_doc_fecha_realizo, asis_doc_cod_docente, asis_doc_cod_mat, asis_doc_seccion,
asis_doc_cod_ciclo,
asis_doc_cod_escuela, asis_doc_minutos)
values (@fecha, @tema, getdate(), @cod_docente, @cod_materia, @cod_seccion,
@cod_ciclo, @cod_escuela, @minutos);
end

我从 C# 调用这个 Sp,这就是我这样做的方式:

 int valor_devuelto = puente.insertar(fecha, txtTema.Text,
Convert.ToDecimal(lblHoras.Text), cod_emp, cod_materia, seccion,
Convert.ToInt32(ciclo.Text), cod_esc);

请注意,(lblHoras.Text) 是从文本框调用的,因此我将其转换为十进制,因为这是我的专栏所期望的。该行调用另一个类中的方法,该方法在我的数据库中调用我的 Sp,并且我在哪里收到错误,这是该代码:

public int insertar(DateTime fecha, string tema, decimal minutos, int docente, string materia_codigo, int seccion, int ciclo, int escuela_cod)
{
int valor = 0;
try
{
cn.Open();
cmd.Connection = cn;
cmd.CommandText = "insertar_pla_asis_doc";
cmd.CommandType = System.Data.CommandType.StoredProcedure;
cmd.Parameters.Add("@fecha", System.Data.SqlDbType.DateTime).Value = fecha;
cmd.Parameters.Add("@tema", System.Data.SqlDbType.VarChar).Value = tema;
cmd.Parameters.Add("@minutos", System.Data.SqlDbType.Decimal).Value = minutos;
cmd.Parameters.Add("@cod_docente", System.Data.SqlDbType.Int).Value = docente;
cmd.Parameters.Add("@cod_materia", System.Data.SqlDbType.VarChar).Value =
materia_codigo;
cmd.Parameters.Add("@cod_seccion", System.Data.SqlDbType.Int).Value = seccion;
cmd.Parameters.Add("@cod_ciclo", System.Data.SqlDbType.Int).Value = ciclo;
cmd.Parameters.Add("@cod_escuela", System.Data.SqlDbType.Int).Value =
escuela_cod;
valor = cmd.ExecuteNonQuery();
cn.Close();
}
catch (Exception ex)
{
}
return valor;
}

每次我运行此代码时都会出现错误:将数字数据转换为小数时出错。 (转换错误)我该如何解决这个问题?

最佳答案

您在过程中的参数声明为

@minutos decimal(2,2)

表示两个数字,都是小数点右边。

检查此示例:

create table #t (d decimal(2,2))
insert #t values (1.5)

增加参数的大小。

关于c# - 从数值数据类型转换为十进制时出错,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23348379/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com