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(); }

      

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

  • 相关阅读:
    oracle 调优3
    ifconfig找不到命令的帖子 精选
    执行计划中各字段各模块描述
    oracle统计信息
    oracle中 rownum与rowid的理
    触发器
    开园第一天
    Asp.net生成htm静态文件的两种途径
    避免刷新页面,自动跳回到页面顶部的办法
    ASP.NET二级域名站点共享Session状态
  • 原文地址:https://www.cnblogs.com/benbenfishfish/p/7561041.html
Copyright © 2011-2022 走看看