使用[本人]创建视图筛选时的一个问题和解答

本文详细阐述了如何在SharePoint中创建一个有效管理多级审批流程的视图,解决审批人筛选与用户ID关联的挑战。通过使用'用户或用户组'字段类型,实现轻松筛选出特定审批人审核过的记录,同时避免了复杂的数据处理和CAML查询的局限性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

问题的提出是基于这样一个需求。比如一个请假条列表,上面跑了一个自己的审批工作流。有权进行审批的经理有多个。而且这个审批工作流也包含了多步审批,每一步都可能有不同的审批人。现在需要创建一个视图,某个经理审核后还想看到自己审核过的请假条。解决的思路是创建一个字段记录每个人审核的人名,之后通过这个字段加一个“ 包含 ”的筛选条件来查看视图。

首先,尝试了使用单行文本类型的栏来保存审批人。当我们在这个栏上添加了一个“包含”[本人]的筛选条件后,视图无法保存,验证通不过,提示“筛选值不是有效的文本字符串”:

看来[本人]这个函数无法用在单行文本上。

由此,就想到换成多行文本。一试果然能够通过。但是添加测试数据后,发现并不能进行预想的筛选。SPD打开该视图查看了一下SharePoint自动生成的CAML,如下:

<Query>
    <OrderBy>
        <FieldRef Name="Title" Ascending="FALSE"/>
    </OrderBy>
    <Where>
        <Contains>
            <FieldRef Name="_x5ba1__x6279__x4eba_"/>
            <Value Type="Integer">
                <UserID Type="Integer"/>
            </Value>
        </Contains>
    </Where>
</Query>

原来,是把UserID直接拿过来做了“包含”操作。随便找了一个UserID,作为测试数据填写到审批人这一栏里,发现筛选正常。比如“张三”对应的ID是13。实际上判断的是包含13的。虽然筛选表面上是成功的,但是实际上这样会造成结果的重叠。(如还有一个UserID是113)。虽然可以通过在 ID号左右添加分割符(比如括号)的方式解决(SPD工作流里可以从工作流上下文里得到当前用户,并返回用户ID),但是CAML查询却不支持<Value Type="Integer">(<UserID Type="Integer"/>)</Value>这样的写法。除非是自己写一个WebPart,取到当前用户的UserId后再拼Value字符串。这样无疑增加了工作量。

其实,SharePoint中有一个更简单的方法能够解决这个问题。就是“用户或用户组”字段类型。

1、创建这个字段值时,使用“用户或用户组”类型。允许多选。


2、视图的“包含”关系就可以直接用“等于”来替代。


3、在工作流更新列表项时,这个字段的值采用在原有值基础上加一个分号,然后再加上当前用户的方式进行保存。

这样,组织出来的视图就能显示包含当前用户的所有审批。并且审批人可以是多个人。

 

参考资料

SharePoint - [Me] = Easy Item Level Security

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值