首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >Linq ExecuteCommand不理解空值

Linq ExecuteCommand不理解空值
EN

Stack Overflow用户
提问于 2009-05-13 19:37:54
回答 9查看 11.2K关注 0票数 22

在使用linq将空值传递给ExecuteCommand()方法时,我遇到了一个问题。我的代码类似于下面的代码:

代码语言:javascript
运行
复制
    public void InsertCostumer(string name, int age, string address)
    {
        List<object> myList = new List<object>();

        myList.Add(name);
        myList.Add(age);
        myList.Add(address);

        StringBuilder queryInsert = new StringBuilder();
        queryInsert.Append("insert into Customers(name, address) values ({0}, {1}, {2})");

        this.myDataContext.ExecuteCommand(queryInsert.ToString(), myList.ToArray());
    }

但是,当参数为空(例如,地址)时,我会得到以下错误:“查询参数不能是‘System.Object’类型。”

如果没有参数为空,则不会发生错误。我知道我的例子中的设计有点差,我只是创建了一个简单的例子来关注这个问题。有什么建议吗?

EN

Stack Overflow用户

发布于 2014-02-18 23:22:58

我通常使用这类东西,不是很理想,但如果你遇到困难,它就能解决问题

代码语言:javascript
运行
复制
            if (myObject != null)
            {
                foreach (var p in ct.GetType().GetProperties())
                {
                    if (p.GetValue(myObject , null) == null)
                    {
                        if (p.PropertyType == typeof(string))
                        {
                            p.SetValue(myObject , "Empty", null);
                        }
                        if (p.PropertyType == typeof(int))
                        {
                            p.SetValue(myObject , 0, null);
                        }
                        if (p.PropertyType == typeof(int?))
                        {
                            p.SetValue(myObject , 0, null);
                        }

                    }
                }
            }

这确保在使用ExecuteCommand中的参数之前,对象中的每个值都有一个值。再说一次,这不是理想的,但它是有效的。

票数 0
EN
查看全部 9 条回答
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/859985

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档