多多色-多人伦交性欧美在线观看-多人伦精品一区二区三区视频-多色视频-免费黄色视屏网站-免费黄色在线

國內最全IT社區平臺 聯系我們 | 收藏本站
阿里云優惠2
您當前位置:首頁 > web前端 > htmlcss > Dynamics 365Online 通過插件中的retrievemultiple消息來過濾產品視圖

Dynamics 365Online 通過插件中的retrievemultiple消息來過濾產品視圖

來源:程序員人生   發布時間:2018-06-11 17:10:05 閱讀次數:10869次

      本篇中要講的是對產品視圖基于某個條件進行過濾顯示,而手段就是通過插件中的retrievemultiple消息,可能很多人都寫過對它都不陌生。

    先來看張插件注冊的截圖,插件的message是retrievemultiple,對應的實體我這里用的是product(為何用它是由于它特殊,由于它特殊才有了本篇博文),事件是pre-operation(這個很好理解,在展現數據之前就要過濾好,1定是pre中的操作了)


     之前寫的代碼是這樣的,判斷InputParameters是否是query,然后再判斷query的實體是否是產品,再進行邏輯處理

if (context.InputParameters.Contains("Query") && context.InputParameters["Query"] is QueryExpression)
                {
                    QueryExpression query = (QueryExpression)context.InputParameters["Query"];
                    
                    if (query.EntityName == "product")
                    {
                        //邏輯處理
                    }
                }
     但在365online(2016on-premises也是一樣的問題)中死活不行,然后斷點調了下發現query.EntityName中竟然沒有product了,調試下來發現取到的都是下面這些鬼

email

queue

solution

savedquery

systemuserroles

rb_userroleviewconfiguration

rb_roleviewconfiguration

userquery 
    很奇怪,product去哪了,不用QueryExpression篩數據那用甚么篩啊,我們把問題往前推到第1個if,看下面這張截圖,你會發現尼瑪變FetchExpression了而不是QueryExpression,所以第1個if都沒進怎樣可能進第2個if呢



      我嘗試的實體不多,目前發現的產品、客戶、聯系人都是這類情況,自定義的實體用QueryExpression都ok的,1開始猜想是否是系統實體都改FetchExpression挑選了,但嘗試了報價單的視圖用QueryExpression過濾是可以的,有時間得好好查查資料看看甚么個情況,如果有人了解其中緣由的也歡迎分享。

    下面奉上FetchExpression的代碼,這里用到了FetchExpression和QueryExpression之間的相互轉化

 if (context.InputParameters["Query"] is FetchExpression)
                {
                    FetchExpression fetch = (FetchExpression)context.InputParameters["Query"];
                    var conversionRequest = new FetchXmlToQueryExpressionRequest
                    {
                        FetchXml = fetch.Query
                    };
                    var conversionResponse =
                        (FetchXmlToQueryExpressionResponse)service.Execute(conversionRequest);

                    // Use the newly converted query expression to make a retrieve multiple
                    // request to Microsoft Dynamics CRM.
                    query = conversionResponse.Query;
                    if (query.EntityName == "product" && context.Depth == 1)
                    {
                        //邏輯
                    }
                    // Convert the query expression to FetchXML.
                    var converRequest = new QueryExpressionToFetchXmlRequest
                    {
                        Query = query
                    };
                    var converResponse =
                        (QueryExpressionToFetchXmlResponse)service.Execute(converRequest);

                    // Use the converted query to make a retrieve multiple request to Microsoft Dynamics CRM.
                    String fetchXml = converResponse.FetchXml;
                    fetch.Query = fetchXml;
                }
 FetchExpression和QueryExpression之間的相互轉化的msdn示例:

 https://msdn.microsoft.com/zh-cn/library/hh547457.aspx

生活不易,碼農辛苦
如果您覺得本網站對您的學習有所幫助,可以手機掃描二維碼進行捐贈
程序員人生
------分隔線----------------------------
分享到:
------分隔線----------------------------
關閉
程序員人生
主站蜘蛛池模板: 久久久久国产精品免费 | 亚洲精品不卡在线 | 日本人护士免费xxxx视频 | 国产精品11页 | 精品无码中出一区二区 | 免费尤物视频 | 中文字幕亚洲综合久久2 | 国产一区二区视频在线观看 | 欧美日韩成人在线视频 | 爱操在线 | 午夜在线观看视频在线播放版 | 欧美黑人性受xxxx喷水 | 婷五月综合 | 天堂在线亚洲 | 免费观看在线永久免费xx视频 | 国产色91 | 免费看黄色的网址 | 中文字幕123| 午夜久久精品 | 日本高清www | 理论片免费观看 | 日韩一级片免费看 | 夜夜操狠狠干 | 伊人久久免费 | 日韩欧美第一区二区三区 | 男女很舒服爽视频免费 | 东方伊人免费在线观看 | 亚洲色图吧 | 日本中文字幕第一页 | 亚洲欧洲精品视频在线观看 | 欧美一区二区二区 | 亚洲 [12p] | 国产亚洲福利一区二区免费看 | 亚洲在线资源 | 免费亚洲视频 | 亚洲欧美手机在线观看 | 国产一区二区三区高清视频 | 国产一级淫片免费视频 | 亚洲综合一区二区 | 在线亚洲欧洲国产综合444 | 在线亚视频 |