PSI - 无法删除资源费率行 [英] PSI - cannot delete resource rate row

查看:45
本文介绍了PSI - 无法删除资源费率行的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我有一项服务通过Project Server 2010中的PSI更新资源的成本费率。

成功包含新费率。但是当我无法删除旧费率时。

当我运行代码时,我看到记录被删除了。但是在执行UpdateResources方法之后,资源不会更新,旧费率仍然可见。

运行服务的用户在Project Server中具有管理权限。


有谁知道我错在哪里?


这就是代码:


resourceSvc = new ResourceWebSvc.Resource();



                resourceSvc.Url = PROJECT_SERVER_URI + RESOURCE_SERVICE_PATH;

                resourceSvc.Credentials = new NetworkCredential(USERNAME,PASSWORD,DOMAIN);



                resourceDS = new ResourceWebSvc.ResourceDataSet();

                

                foreach(EPMResources中的EPMResource资源)

                {

                    eAcessoUser eAcessoInfo = new eAcessoUser();

                    eAcessoInfo = eAcessoUsers.Where(u => u.ID.Equals(resource.eAcessoID))。FirstOrDefault();



                    if(eAcessoInfo!= null)

                    {                                                

                        resourceDS = resourceSvc.ReadResource(resource.GUID);

                        

                        if(resourceDS.ResourceRates [resourceDS.ResourceRates.Count - 1] .RES_STD_RATE!= Convert.ToDouble(eAcessoInfo.CostValue.Value))

                        {

                            if(resourceDS.ResourceRates.Count> = 25)

                            {

                                ResourceWebSvc.ResourceDataSet.ResourceRatesRow rowDel = resourceDS.ResourceRates [1];

                                if(!rowDel.IsRES_RATE_EFFECTIVE_DATENull())

                                {

                                    rowDel.Delete();

                                    rowDel.AcceptChanges();

                                    resourceDS.ResourceRates.AcceptChanges();

                                    resourceDS.AcceptChanges();

                                }¥b $ b                            }


                            ResourceWebSvc.ResourceDataSet.ResourceRatesRow row = resourceDS.ResourceRates.NewResourceRatesRow();

                            row.RES_RATE_EFFECTIVE_DATE = eAcessoInfo.EffectiveDate.Value;

                            row.RES_STD_RATE = Convert.ToDouble(eAcessoInfo.CostValue.Value);

                            row.RES_OVT_RATE = Convert.ToDouble(eAcessoInfo.OvertimeValue.Value);

                            //row.RES_RATE_TABLE

                            row.RES_UID = resource.GUID;

                            resourceDS.ResourceRates.AddResourceRatesRow(行);                                
                              



                            if(resourceDS.Resources [0] .IsRES_CHECKOUTBYNull())

                            {

                                resourceSvc.CheckOutResources(new Guid [] {resource.GUID});

                            }


                            resourceSvc.UpdateResources(resourceDS,false,false);

                            resourceSvc.CheckInResources(new Guid [] {resource.GUID},true);

                            resourceDS.Resources [0] .SetModified();

                        }¥b $ b                                                             

                    }¥b $ b                }


                resourceDS.Dispose();

                resourceSvc.Dispose();


解决方案

您好ipaquino,


尝试在使用UpdateResource方法之前调用resourceDS.Resources [0] .SetModified()。


Greets

Maik


I have a service that does the update of resource's cost rate via PSI in Project Server 2010.
New rates are included successfully. But when I can't delete old rates.
When I run the code, I see that the records are deleted. But after execute the UpdateResources method, the resource is not updated and old rates remain visible.
The user who runs the service has administrative permission in Project Server.

Does anyone know where I could be wrong?

That's the code:

resourceSvc = new ResourceWebSvc.Resource();

                resourceSvc.Url = PROJECT_SERVER_URI + RESOURCE_SERVICE_PATH;
                resourceSvc.Credentials = new NetworkCredential(USERNAME, PASSWORD, DOMAIN);

                resourceDS = new ResourceWebSvc.ResourceDataSet();
                
                foreach (EPMResource resource in EPMResources)
                {
                    eAcessoUser eAcessoInfo = new eAcessoUser();
                    eAcessoInfo = eAcessoUsers.Where(u => u.ID.Equals(resource.eAcessoID)).FirstOrDefault();

                    if (eAcessoInfo != null)
                    {                                                 
                        resourceDS = resourceSvc.ReadResource(resource.GUID);
                        
                        if (resourceDS.ResourceRates[resourceDS.ResourceRates.Count - 1].RES_STD_RATE != Convert.ToDouble(eAcessoInfo.CostValue.Value))
                        {
                            if (resourceDS.ResourceRates.Count >= 25)
                            {
                                ResourceWebSvc.ResourceDataSet.ResourceRatesRow rowDel = resourceDS.ResourceRates[1];
                                if (!rowDel.IsRES_RATE_EFFECTIVE_DATENull())
                                {
                                    rowDel.Delete();
                                    rowDel.AcceptChanges();
                                    resourceDS.ResourceRates.AcceptChanges();
                                    resourceDS.AcceptChanges();
                                }
                            }

                            ResourceWebSvc.ResourceDataSet.ResourceRatesRow row = resourceDS.ResourceRates.NewResourceRatesRow();
                            row.RES_RATE_EFFECTIVE_DATE = eAcessoInfo.EffectiveDate.Value;
                            row.RES_STD_RATE = Convert.ToDouble(eAcessoInfo.CostValue.Value);
                            row.RES_OVT_RATE = Convert.ToDouble(eAcessoInfo.OvertimeValue.Value);
                            //row.RES_RATE_TABLE
                            row.RES_UID = resource.GUID;
                            resourceDS.ResourceRates.AddResourceRatesRow(row);                                                               

                            if (resourceDS.Resources[0].IsRES_CHECKOUTBYNull())
                            {
                                resourceSvc.CheckOutResources(new Guid[] { resource.GUID });
                            }

                            resourceSvc.UpdateResources(resourceDS, false, false);
                            resourceSvc.CheckInResources(new Guid[] { resource.GUID }, true);
                            resourceDS.Resources[0].SetModified();
                        }
                                                             
                    }
                }

                resourceDS.Dispose();
                resourceSvc.Dispose();

解决方案

Hi ipaquino,

try to call call resourceDS.Resources[0].SetModified() before you use the UpdateResource method.

Greets
Maik


这篇关于PSI - 无法删除资源费率行的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆