0
我正在使用'wcf数据服务工具包'进行CURD操作。 获取/添加/删除工作正常,但更新失败。更新无法在wcf dataservice工具包中工作
在更新的情况下,我看到'GetOne()'方法被调用,但Save()不会被调用。
服务代码:
public class UserService : ODataService<UserContext>
{
public static void InitializeService(DataServiceConfiguration config)
{
config.SetEntitySetAccessRule("*", EntitySetRights.All);
config.DataServiceBehavior.MaxProtocolVersion = DataServiceProtocolVersion.V2;
}
}
库编号:
public User GetOne(string id)
{
return _session.Query<User>().Where(a => a.Id == int.Parse(id)).SingleOrDefault();
}
public void Save(User u)
{
_session.Store(u);
_session.SaveChanges();
}
数据上下文代码:
public class UserContext : ODataContext
{
public IQueryable<User> Users
{
get { return base.CreateQuery<User>(); }
}
public override object RepositoryFor(string fullTypeName)
{
return new UserRepository();
}
}
型号代码:
[DataServiceKey("Id")]
public class User
{
public int Id { get; set; }
public string UserName { get; set; }
public string Password { get; set; }
public string UserEmailAddress { get; set; }
}
这里是我的测试案例:
[TestMethod]
public void TestUpdateUser()
{
var context = new UserService.UserContext(new Uri("http://localhost:59050/UserService.svc"));
var user = context.Users.Where(a => a.Id == 385).SingleOrDefault();
user.UserEmailAddress = "[email protected]";
context.UpdateObject(user);
context.SaveChanges();
var context2 = new UserService.UserContext(new Uri("http://localhost:59050/UserService.svc"));
var updated = context.Users.Where(a => a.Id == 385).SingleOrDefault();
Assert.AreEqual("[email protected]", updated.UserEmailAddress)
}
我更新我的模型代码的问题。此外,日志问题仅针对根网址,其余服务工作为获取/添加/删除(除更新)。 – NiTiN
您的项目中是否包含工具包代码?如果是这样,在ODataContext文件中放置一个断点。该文件包含一个名为SaveChanges的方法,您将能够看到它正在尝试执行的操作。另外请确保您使用的是http://wcfdstoolkit.codeplex.com/SourceControl/network/Forks/Airslash/SeptemberRelease这个版本的代码,因为这里有几个修正。 – SCB
我正在使用nuget包。将尝试代码并让你知道,谢谢! – NiTiN