sinat_31457711 2015-11-12 13:26 采纳率: 0%
浏览 4616

【问题】其他信息: 必须声明标量变量 "@XXX"...

using Model;
using System;
using System.Collections.Generic;
using System.Data.SqlClient;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using Utility;

namespace DAL
{
public class CommodityDAL
{
public bool EditCM(CommodityModel cm)
{
string sql = @"insert into Commodity(CommodityName, SortID, CommodityPrice, IsDiscount, ReducedPrice) values(@Name,@ID,@Price,@Discount,@RPrice)";
SqlParameter[] ps = {
new SqlParameter("@Name",cm.CommodityName),
new SqlParameter("@ID",cm.SortID),
new SqlParameter("@Price",cm.CommodityPrice),
new SqlParameter("@Discount",cm.IsDiscount),
new SqlParameter("@RPrice",cm.ReducePrice)
};

        return SqlHelper.ExecuteNonQuery(sql) > 0;
    }

}

}

发生异常:
“System.Data.SqlClient.SqlException”类型的未经处理的异常在 System.Data.dll 中发生

其他信息: 必须声明标量变量 "@Name"。

请问给位大神,这是怎么回事?断点查看
cm.CommodityName
cm.SortID
cm.CommodityPrice
cm.IsDiscount
cm.ReducePrice
都有相应的值!
为什么就传不进去呢?图片说明图片说明

  • 写回答

1条回答 默认 最新

  • 暖枫无敌 博客专家认证 2015-11-13 05:27
    关注

    string sql = @"insert into Commodity(CommodityName, SortID, CommodityPrice, IsDiscount, ReducedPrice) values(@Name,@ID,@Price,@Discount,@RPrice)";

    去掉字符串前面的@符号

    评论

报告相同问题?

悬赏问题

  • ¥15 ads仿真结果在圆图上是怎么读数的
  • ¥20 Cotex M3的调试和程序执行方式是什么样的?
  • ¥20 java项目连接sqlserver时报ssl相关错误
  • ¥15 一道python难题3
  • ¥15 用matlab 设计一个不动点迭代法求解非线性方程组的代码
  • ¥15 牛顿斯科特系数表表示
  • ¥15 arduino 步进电机
  • ¥20 程序进入HardFault_Handler
  • ¥15 oracle集群安装出bug
  • ¥15 关于#python#的问题:自动化测试