zoukankan      html  css  js  c++  java
  • EF执行存储工程报错 String[4]: Size 属性具有无效大小值 0。

    EF中执行存储过程报错 String[4]: Size 属性具有无效大小值 0

    排查后是如下问题所致,给定的参数没有设定大小(加入红框内的就可以了)

     private string GetCode(MCPERPEntities db, string code)
            {
    
                List<SqlParameter> paramArray =

    new List<SqlParameter>(); paramArray.Add(new SqlParameter("@I_CodeName", code)); paramArray.Add(new SqlParameter("@I_Year", DateTime.Now.ToString("yyyy"))); paramArray.Add(new SqlParameter("@I_Month", DateTime.Now.ToString("MM"))); paramArray.Add(new SqlParameter("@I_Day", DateTime.Now.ToString("dd"))); SqlParameter param = new SqlParameter("@O_Code", SqlDbType.NVarChar); param.Direction = ParameterDirection.Output; paramArray.Add(param); paramArray[0].SqlDbType = SqlDbType.VarChar; paramArray[0].Size = 200; paramArray[1].SqlDbType = SqlDbType.VarChar; paramArray[1].Size = 4; paramArray[2].SqlDbType = SqlDbType.VarChar; paramArray[2].Size = 2; paramArray[3].SqlDbType = SqlDbType.VarChar; paramArray[3].Size = 2; try { db.Database.ExecuteSqlCommand("EXEC P_Sys_GetAutoCode @I_CodeName,@I_Year,@I_Month,@I_Day,@O_Code out", paramArray.ToArray()); } catch (Exception ex) { throw; } return paramArray[3].Value.ToString(); }

      

     写的比较粗糙因为是一个简单的测试就没有写的很细致.希望能帮到遇到这个问题的同学.

  • 相关阅读:
    uva 1584.Circular Sequence
    成为Java顶尖程序员 ,看这11本书就够了
    java 线程同步 原理 sleep和wait区别
    xargs -r
    java
    事故分析
    各大互联网公司架构演进之路汇总
    char 汉字
    nginx优化之request_time 和upstream_response_time差别
    学习进度05
  • 原文地址:https://www.cnblogs.com/benbenfishfish/p/7561041.html
Copyright © 2011-2022 走看看