对于Silverlight中添加DomainService的对话框只能选择一次,如果数据库表增加就没有办法进行操作,只能将原有的DomainService删除后重新添加,本教程就是帮你解决此问题,我们选看一下DomainService添加界面如下
界面中没有选择的实体是不能进行操作的,我们可以通过手动的方式将这些实体添加到DomainService中供Silverlight操作,这样我们就可以根据自己需要进行灵活操作。
先将生成的DomainService1类改为局部类
public partial class DomainService1 : LinqToEntitiesDomainService<MyBookShopEntities>
然后自己创建一个 DomainService1的局部类,就可以进行手动添加操作
1.必须添加一个查询操作然后才能添加其它操作,如果不添加查询操作编译时就会出现如下错误:
错误 1 域方法“UpdateUserRoles”的参数“data”必须是 DomainService 公开的实体类型。该实体类型可以直接在查询操作中公开,也可以通过关联间接公开。
例如我们添加UserRoles的查询操作,代码如下:
public IQueryable<UserRoles> GetUserRoles()
{
return this.ObjectContext.UserRoles;
}
然后就可以添加其它的查询方法,例如条件查询:
public IQueryable<UserRoles> GetUserRolesByName(string name)
{
return this.ObjectContext.UserRoles.Where(r=>r.Name.StartsWith(name);
}
分页查询:(分页要先排序才可以)
public IQueryable<Books> GetBooksByPage(int pageIndex,int pageSize)
{
return this.ObjectContext.Books.OrderBy(b=>b.Id).Skip(pageIndex * pageSize).Take(pageSize);
}
在Silverlight中调用请参考前面的文章
2.添加增加方法,代码如下:
public void InsertUserRoles(UserRoles data)
{
if ((data.EntityState != EntityState.Detached))
{
this.ObjectContext.ObjectStateManager.ChangeObjectState(data, EntityState.Added);
}
else
{
this.ObjectContext.UserRoles.AddObject(data);
}
}
3.添加更新操作,代码如下:
public void UpdateUserRoles(UserRoles data)
{
this.ObjectContext.UserRoles.AttachAsModified(data, this.ChangeSet.GetOriginal(data));
}
如果要添加自定义的更新方法就需要自己写一个方法,这个方法有如下要求:
a.方法返回值不要用void,这要不方便使用OptionHander调用(参照前面的文章)
例如更新代码如下:
public void UpdateUserRolesEx(UserRoles data)
{
var old = this.ObjectContext.UserRoles.Where(r => r.Id == data.Id).Single();
old.Name = data.Name;
this.ObjectContext.UserRoles.AttachAsModified(old, this.ChangeSet.GetOriginal(old));
}
就会碰到这样的错误:
因此这个方法需要改成如下格式:
public bool UpdateUserRolesEx(UserRoles data)
{
try
{
var old = this.ObjectContext.UserRoles.Where(r => r.Id == data.Id).Single();
old.Name = data.Name;
this.ObjectContext.UserRoles.AttachAsModified(old, this.ChangeSet.GetOriginal(old));
return true;
}
catch
{
return false;
}
}
Silverlight中UserRoleBLL调用代码如下:
public static void UpdateUserRolesEx(OptionHander oh,UserRoles role)
{
var m = DB.db.UpdateUserRolesEx(role);
m.Completed += (a, b) => oh(m.Value);
}
4.删除操作
public void DeleteUserRoles(UserRoles data)
{
if ((data.EntityState != EntityState.Detached))
{
this.ObjectContext.ObjectStateManager.ChangeObjectState(data, EntityState.Deleted);
}
else
{
this.ObjectContext.UserRoles.Attach(data);
this.ObjectContext.UserRoles.DeleteObject(data);
}
}
扩展删除方法:
public bool DeleteUserRoleById(int id)
{
try
{
var old = this.ObjectContext.UserRoles.Where(r => r.Id == id).Single();
DeleteUserRoles(old);
return true;
}
catch
{
return false;
}
}
调用参考前面的文章