对于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; } }
调用参考前面的文章