CRM 权限内可查看的记录数
CREATE FUNCTION dbo.fn_GetFilteredIdsSqlString
(
@SystemUserId VARCHAR(36) ,
@ObjectTypeCode VARCHAR(10) ,
@entityname VARCHAR(100)
)
RETURNS NVARCHAR(max)
AS
BEGIN DECLARE @sqlText NVARCHAR(4000)
SET @sqlText = ' SELECT ' + @entityname + 'id id from ' + @entityname
+ ' JOIN SystemUserBase u ON ( u.SystemUserId = '''
+ @SystemUserId + ''' AND u.IsDisabled = 0 ) '
+ ' CROSS JOIN dbo.fn_GetMaxPrivilegeDepthMask_SQL('
+ @ObjectTypeCode + ',''' + @SystemUserId + ''' ) pdm '
+ ' WHERE ( ' + ' pdm.PrivilegeDepthMask IS NOT NULL '
+ ' AND ( ' + ' [' + @entityname + '].OwnerId IN ( '
+ ' SELECT OwnerId '
+ ' FROM [dbo].[fn_GetOwnerIdsForFilteredView](u.SystemUserId,'
+ @ObjectTypeCode + ') ) ' + ' OR EXISTS ( SELECT 1 '
+ ' WHERE ( ( ( ( pdm.PrivilegeDepthMask & 0x4 ) != 0 ) OR ( ( pdm.PrivilegeDepthMask & 0x2 ) != 0 ) '
+ ' AND [' + @entityname + '].[OwningBusinessUnit] IN ( '
+ ' SELECT BusinessUnitId FROM SystemUserBusinessUnitEntityMap WITH ( NOLOCK ) WHERE SystemUserId = '''
+ @SystemUserId + ''' AND ObjectTypeCode =' + @ObjectTypeCode
+ ' ) ) '
+ ' OR ( ( ( pdm.PrivilegeDepthMask & 0x8 ) != 0 ) AND ['
+ @entityname + '].[OwningBusinessUnit] IS NOT NULL) ) ' + ' OR ['
+ @entityname + '].' + @entityname + 'id IN ( '
+ ' SELECT ObjectId FROM [dbo].[fn_GetSharedRecordIdsForFilteredView]('''
+ @SystemUserId + ''' , ' + @ObjectTypeCode + ') ) ) ) )' RETURN @sqlText END
因为存在动态SQL,所以不好写成 表值函数.暂时只能这样了.
CRM 权限内可查看的记录数的更多相关文章
- sqlserver sql语句查看分区记录数、查看记录所在分区
select count(1) ,$PARTITION.WorkDatePFN(workdate) from imgfile group by $PARTITION.WorkDatePFN(workd ...
- 无依赖简单易用的Dynamics 365实体记录数计数器并能计算出FetchXml返回的记录数
本人微信公众号:微软动态CRM专家罗勇 ,回复278或者20180812可方便获取本文,同时可以在第一间得到我发布的最新博文信息,follow me!我的网站是 www.luoyong.me . 我们 ...
- 亿方云(用电话或者qq沟通是远远不够的,容易忘还不能反复催,最好的方式就是指定一个平台,团队内的人定期查看最新记录)
作者:城年链接:http://www.zhihu.com/question/20579359/answer/106319200来源:知乎著作权归作者所有,转载请联系作者获得授权. 更新,文字发完后,好 ...
- Dynamic CRM 2015学习笔记(6)没有足够的权限 - 您没有访问这些记录的权限。请联系 Microsoft Dynamics CRM 管理员
我们经常遇到下面这种问题:没有足够的权限 - 您没有访问这些记录的权限.请联系 Microsoft Dynamics CRM 管理员. 下面将详细介绍下如何解决这种问题:进不了CRM系统:进了CRM ...
- 查看mysql库中所有表的大小和记录数
查看mysql库中所有表的大小和记录数 ,), 'MB') as total_size FROM information_schema.TABLES WHERE TABLE_SCHEMA='datab ...
- navicat查看mysql数据表记录数不断变化
在使用navicat进行数据库管理的时候,在查看表对象的时候会发现,每次刷新,数据表的记录数不断变化,尤其是大表. 对于100万的数据经常会显示九十几万,当然通过count(*)出来的数据是正确的. ...
- MySQL数据库查看数据表占用空间大小和记录数
MySQL数据库中每个表占用的空间.表记录的行数的话,可以打开MySQL的 information_schema 数据库.在该库中有一个 TABLES 表,这个表主要字段分别是: TABLE_SCHE ...
- SQLSERVER 数据库查看各表的记录数
select a.name as 表名,max(b.rows) as 记录条数 from sysobjects a ,sysindexes b where a. ...
- SQL Server 2008系统信息查询常用命令 查看表大小、记录数等
1.返回所有数据库信息(数据库名,创建日期,存储路径等). use master; GO select * from dbo.sysdatabases 2.返回当前数据库所有对象(可根据type字 ...
随机推荐
- day43 数据库学习 转自egon 老师博客 单表查询和多表查询
一 单表查询的语法 SELECT 字段1,字段2... FROM 表名 WHERE 条件 GROUP BY field HAVING 筛选 ORDER BY field LIMIT 限制条数 二 关键 ...
- cget cmake 包管理工具
cget 是一个方便的进行cmake 包下载以及安装的工具 包含的特性 非侵入,无需编写特殊钩子就可以使用cmake 开箱即用, 由于使用了标准的基于cmake的方式,直接可以使用基于cmkae 的软 ...
- oracle-sql优化器
优化器optimizer Oracle 执行计划(Explain Plan) 说明 http://langgufu.iteye.com/blog/2158163 explain plan是一个dml语 ...
- MySQL 5.7新特性之在线收缩undo表空间
1. MySQL 5.5时代的undo log 在MySQL5.5以及之前,大家会发现随着数据库上线时间越来越长,ibdata1文件(即InnoDB的共享表空间,或者系统表空间)会越来越大,这会造成2 ...
- C# 使用委托实现多线程调用窗体的四种方式(转)
1.方法一:使用线程 功能描述:在用c#做WinFrom开发的过程中.我们经常需要用到进度条(ProgressBar)用于显示进度信息.这时候我们可能就需要用到多线程,如果不采用多线程控制进度条,窗口 ...
- Spring Cloud Eureka Server使用(注册中心)
一.Spring Cloud Eureka 基于Netflix Eureka做了二次封装 由两个组件组成 Eureka Server 注册中心, 供服务注册的服务器 Eureka Client 服务注 ...
- 在Ubuntu上使用noip动态域名的方法(ddns)
首先,注册一个noip.com的帐号. 注册的步骤见这篇教程:http://www.cnblogs.com/infopi/p/3991407.html 建立目录 第1行进入当前用户的home目录 第2 ...
- 大数据离线分析平台 JavaSDK数据收集引擎编写
JavaSDK设计规则 JavaSDK提供两个事件触发方法,分别为onChargeSuccess和onChargeRefund.我们在java sdk中通过一个单独的线程来发送线程数据,这样可以减少对 ...
- 前端大神讲解,初级程序与高级程序写表格变色的区别,dom 0 与dom 1
我们在遇到表格行数太多时,往往会眼花缭乱,下一行看成对应上一行.就要遇到写鼠标移动那行,那行高亮显示. 这里用到一个this关键字: 在面向对象里,this代表对象本身. 在这里只要记住,谁调用这个函 ...
- Docker Dockerfile 一
1.概述 创建Docker镜像的方式有三种 docker commit命令:由容器生成镜像: Dockerfile文件+docker build命令: 从本地文件系统导入:OpenVZ的模板. 关于这 ...