关于复合实体注意的一些问题

    现在定义两个类
    public class Order
    {
        int orderId;
        Address address; //Address 类
    }
    public class Address
    {
        string email;
        string address;
    }
    我在给存储过程附值的时候这样写:
    db.CreateInParm("@OrderId", SqlDbType.Int, 4, Order.orderId)
    db.CreateInParm("@Email", SqlDbType.VarChar, 30, Order.Address.email)
    db.CreateInParm("@Address", SqlDbType.VarChar, 50, Order.Address.address)

    在程序中创建实体:
    Order order = new Order();
    order.orderId = 1;
    order.Address.email = "kt323@163.com";
    order.Address.address = "KT323-1班";

    可是这样的话,当我调用存储过程的时候会出错,会提示没有实例
    于是改成:
    Order order = new Order();
    order.orderId = 1;
    Address myaddress = new Address();
    myaddress.email = "kt323@163.com";
    myaddress.address = "KT323-1班";

    这样调用是正确的,可是这里又遇到一个问题,如果是用于WebService中调用,我如何得到Address类型?我的一个笨方法是在Order这个WebService中返回一个Address类型:
        [WebMethod(Description = "获得Address类型")]
        public Address GetAddressEntity()
        {
            return (new Address());
        }

    这样在WebService调用端就能使用OrderWebService.Address去声明一个Address对象,于是实现整个Order对象的实例化,保证调用存储过程不出错。
    关于如何在WebService得到Address类型,不知道高手们有什么什么其他更好的方法。
posted on 2007-10-24 09:32 小火 阅读( ...) 评论( ...)   编辑 收藏

转载于:https://www.cnblogs.com/zhxucan/articles/935546.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值