现在定义两个类
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类型,不知道高手们有什么什么其他更好的方法。
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类型,不知道高手们有什么什么其他更好的方法。