Silverlight 中 DomainService的手动扩充

对于Silverlight中添加DomainService的对话框只能选择一次,如果数据库表增加就没有办法进行操作,只能将原有的DomainService删除后重新添加,本教程就是帮你解决此问题,我们选看一下DomainService添加界面如下

Silverlight 中 DomainService的手动扩充_第1张图片

界面中没有选择的实体是不能进行操作的,我们可以通过手动的方式将这些实体添加到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;
            }
        }

调用参考前面的文章

你可能感兴趣的:(Silverlight 中 DomainService的手动扩充)