博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
解决一个报表EdmFunction报错问题
阅读量:6161 次
发布时间:2019-06-21

本文共 7092 字,大约阅读时间需要 23 分钟。

    最近测试组提了一个bug,说是某个报表点击查询报错,查看错误log,错误信息如下。

类型“Ticket.Data.SqlFuns”上指定的方法“Boolean ContainsAll(System.String, System.String)”无法转换为 LINQ to Entities 存储表达式。

定位到错误行,发现是一个自定义的SQLCLR函数,如下代码。

为什么使用CLR函数ContainsAll报错

理论上CLR函数可以用在lambda表达式中,但是为什么现在突然就不行了呢?

依据错误提示,首先想到的是,函数ContainsAll已经不在edmx文件中了,查看edmx文件的历史记录,对比发现,果然CLR函数被删除了,如下图。

解决方案:

用新的'数据库生成工作流'文件,重新生成,结果edmx就会包含那些CLR函数了。

附数据库生成工作流文件:

GenerateDatabaseScriptWorkflow_1
System.Activities
System
Microsoft.VisualBasic
System.Xml.Linq
System.Xml
System.Xml.Serialization
System.Activities
mscorlib
System
System.Core
System.ComponentModel.Composition
System.ServiceModel
Microsoft.VisualBasic.Editor
Microsoft.VisualBasic.LanguageService
Microsoft.VisualBasic
Microsoft.VisualStudio.VisualBasic.LanguageService
System.Xml.Linq
System.Xml
System.Data
System.Runtime.Serialization
[Ssdl]
[Ssdl.Replace("</Schema>", " <Function Name=""ContainsAll"" ReturnType=""bit"" Aggregate=""false"" BuiltIn=""false"" NiladicFunction=""false"" IsComposable=""true"" ParameterTypeSemantics=""AllowImplicitConversion"" Schema=""dbo"">" & vbNewLine & " <Parameter Name=""input"" Type=""nvarchar(max)"" Mode=""In"" />" & vbNewLine & " <Parameter Name=""search"" Type=""nvarchar"" Mode=""In"" />" & vbNewLine & " </Function>" & vbNewLine & " <Function Name=""ContainsAny"" ReturnType=""bit"" Aggregate=""false"" BuiltIn=""false"" NiladicFunction=""false"" IsComposable=""true"" ParameterTypeSemantics=""AllowImplicitConversion"" Schema=""dbo"">" & vbNewLine & " <Parameter Name=""input"" Type=""nvarchar(max)"" Mode=""In"" />" & vbNewLine & " <Parameter Name=""search"" Type=""nvarchar"" Mode=""In"" />" & vbNewLine & " </Function>" & vbNewLine & " <Function Name=""ContainsOne"" ReturnType=""bit"" Aggregate=""false"" BuiltIn=""false"" NiladicFunction=""false"" IsComposable=""true"" ParameterTypeSemantics=""AllowImplicitConversion"" Schema=""dbo"">" & vbNewLine & " <Parameter Name=""input"" Type=""nvarchar(max)"" Mode=""In"" />" & vbNewLine & " <Parameter Name=""search"" Type=""nvarchar"" Mode=""In"" />" & vbNewLine & " </Function>" & vbNewLine & " <Function Name=""GetDateTimeString"" ReturnType=""nvarchar"" Aggregate=""false"" BuiltIn=""false"" NiladicFunction=""false"" IsComposable=""true"" ParameterTypeSemantics=""AllowImplicitConversion"" Schema=""dbo"">" & vbNewLine & " <Parameter Name=""input"" Type=""datetime"" Mode=""In"" />" & vbNewLine & " <Parameter Name=""format"" Type=""nvarchar"" Mode=""In"" />" & vbNewLine & " </Function>" & vbNewLine & " <Function Name=""RegexIsMatch"" ReturnType=""bit"" Aggregate=""false"" BuiltIn=""false"" NiladicFunction=""false"" IsComposable=""true"" ParameterTypeSemantics=""AllowImplicitConversion"" Schema=""dbo"">" & vbNewLine & " <Parameter Name=""input"" Type=""nvarchar(max)"" Mode=""In"" />" & vbNewLine & " <Parameter Name=""pattern"" Type=""nvarchar"" Mode=""In"" />" & vbNewLine & " <Parameter Name=""isIgnoreCase"" Type=""bit"" Mode=""In"" />" & vbNewLine & " </Function>" & vbNewLine & " <Function Name=""RegexMatch"" ReturnType=""nvarchar"" Aggregate=""false"" BuiltIn=""false"" NiladicFunction=""false"" IsComposable=""true"" ParameterTypeSemantics=""AllowImplicitConversion"" Schema=""dbo"">" & vbNewLine & " <Parameter Name=""input"" Type=""nvarchar(max)"" Mode=""In"" />" & vbNewLine & " <Parameter Name=""pattern"" Type=""nvarchar"" Mode=""In"" />" & vbNewLine & " <Parameter Name=""isIgnoreCase"" Type=""bit"" Mode=""In"" />" & vbNewLine & " <Parameter Name=""groupnum"" Type=""int"" Mode=""In"" />" & vbNewLine & " </Function>" & vbNewLine & " <Function Name=""RegexReplace"" ReturnType=""nvarchar"" Aggregate=""false"" BuiltIn=""false"" NiladicFunction=""false"" IsComposable=""true"" ParameterTypeSemantics=""AllowImplicitConversion"" Schema=""dbo"">" & vbNewLine & " <Parameter Name=""input"" Type=""nvarchar(max)"" Mode=""In"" />" & vbNewLine & " <Parameter Name=""pattern"" Type=""nvarchar"" Mode=""In"" />" & vbNewLine & " <Parameter Name=""replacement"" Type=""nvarchar"" Mode=""In"" />" & vbNewLine & " <Parameter Name=""isIgnoreCase"" Type=""bit"" Mode=""In"" />" & vbNewLine & " </Function>" & vbNewLine & "</Schema>")]
d5kBQzpcUHJvZ3JhbSBGaWxlcyAoeDg2KVxNaWNyb3NvZnQgVmlzdWFsIFN0dWRpbyAxMS4wXENvbW1vbjdcSURFXEV4dGVuc2lvbnNcTWljcm9zb2Z0XEVudGl0eSBGcmFtZXdvcmsgVG9vbHNcREJHZW5cVGFibGVQZXJUeXBlU3RyYXRlZ3kuV2l0aC5GdW5jdGlvbi54YW1sDTIDPg4CAQEzBTPGAwIBDTQFOw4CAQk8BTy4AQIBAjMwMzgCARQzuwMzwwMCARIzgAEzhwECARAznwEznAICAQ8zsQIzrwMCAQ42MTY3AgEKPFw8bAIBBzxCPEkCAQU8rQE8tQECAQM=
True

因大字段导致的outofmemory内存溢出问题

    解决了CLR函数报错的问题后,发现又存在性能问题,原因在于审核历史记录表AuditHistory中字段ItemContent存的是json字符串,而这个字符串很大很大,所以如果查询的数据量很大的话,就会报out of memory内存溢出的错误。

    数据库数据类型及数据:

解决方案:

1,只查询需要的字段,并且先不要包含ItemContent,因为该字段内容太大。

2,ItemContent改为二进制存储

    方法1只是临时的解决方案,因为查询出结果后,后面会foreach,拿到每条记录的ItemContent并反序列化,因为我前面没有包括这个字段,所以每条记录在反序列化之前还会去查一次数据库为了拿到ItemContent,这样如果数据量一大,就会有可能查询超时。

    要想从根本上解决这个问题,最好的方法是将ItemContent改为二进制存储,这样体积就会小很多。

    保存为二进制:var localResponse = localRS.ToBinary();

///         /// 对象转换binary        ///         ///         /// 
public static byte[] ToBinary(this object input) { var jsonStr = input.ToJson(); if (!jsonStr.IsNullOrEmpty()) { return jsonStr.GZipCompress(); } return null; }

    拿到二进制数据反序列化:

///         /// binary转换对象        ///         ///         /// 
public static T FromBinary
(this byte[] input) { var jsonStr = input.GZipDecompress(); if (!jsonStr.IsNullOrEmpty()) { return jsonStr.FromJson
(); } return default(T); }

转载地址:http://bsefa.baihongyu.com/

你可能感兴趣的文章
Mysql -- You can't specify target table 'address' for update in FROM clause
查看>>
使用局部标准差实现图像的局部对比度增强算法。
查看>>
2017-2018-1 20165313 《信息安全系统设计基础》第八周学习总结
查看>>
《代码敲不队》第四次作业:项目需求调研与分析
查看>>
菜鸡互啄队—— 团队合作
查看>>
HttpWebRequest的GetResponse或GetRequestStream偶尔超时 + 总结各种超时死掉的可能和相应的解决办法...
查看>>
SparseArray
查看>>
第二章
查看>>
android背景选择器selector用法汇总
查看>>
[转]Paul Adams:为社交设计
查看>>
showdialog弹出窗口刷新问题
查看>>
java
查看>>
Vue.js连接后台数据jsp页面  ̄▽ ̄
查看>>
关于程序的单元测试
查看>>
mysql内存优化
查看>>
都市求生日记第一篇
查看>>
Java集合---HashMap源码剖析
查看>>
SQL优化技巧
查看>>
thead 固定,tbody 超出滚动(附带改变滚动条样式)
查看>>
Dijkstra算法
查看>>