今天突然CodeSmith 生成代码失败了,Error: 无法将类型为“System.Int32”的对象强制转换为类型“System.String”。
最后检查发现是存储过程加了默认参数,但这个默认参数不是string类型,就会导致这个问题,大家注意一下。
------------更新------------
今天反复调试,发现只是函数的默认值会导致它报错。
CREATE FUNCTION [dbo].[RegexMatch](@Regex [nvarchar](max), @Input [nvarchar](max), @regexOptions [int]=0, @beginning [int]=0, @length [int]=0)
RETURNS [nvarchar](max) WITH EXECUTE AS CALLER
AS
EXTERNAL NAME [TMS.SqlRegexExtend].[TMS.SqlRegexExtend.RegexExtend].[Match]
GO
---------------- Generation started -----------------
Error: 无法将类型为“System.Int32”的对象强制转换为类型“System.String”。
Stack Trace:
在 System.Data.SqlClient.SqlBuffer.get_String()
在 SchemaExplorer.SqlSchemaProvider.GetParametersFromReader(IDictionary`2 commands, SafeDataReader reader, Boolean populateCommand)
在 SchemaExplorer.SqlSchemaProvider.PopulateCommandParameters(SafeDataReader reader, IList`1 commands)
在 SchemaExplorer.SqlSchemaProvider.GetCommands(String connectionString, DatabaseSchema database)
在 SchemaExplorer.CachedSchemaProviderProxy.GetCommands(String connectionString, DatabaseSchema database)
在 SchemaExplorer.DatabaseSchema.get_Commands()
在 MoM.Templates.CommonSqlCode.GetCustomProcedures(TableSchema table) 位置 d:\myProject\NetTiers\TemplateLib\CommonSqlCode.cs:行号 5087
在 _CodeSmith.NetTiers_cst.StoredProceduresXml.__RenderMethod1(TextWriter writer, Control control) 位置 d:\myProject\NetTiers\DataAccessLayer.SqlClient\StoredProceduresXml.cst:行号 895
在 CodeSmith.Engine.Control.RenderChildren(TextWriter writer)
在 CodeSmith.Engine.CodeTemplate.Render(TextWriter writer)
在 CodeSmith.Engine.CodeTemplate.RenderToString()
在 CodeSmith.Engine.CodeTemplate.RenderToFile(OutputFile outputFile, Boolean overwrite)
在 _CodeSmith.NetTiers_cst.RenderToFile(String templateName, String path, Boolean overwrite) 位置 d:\myProject\NetTiers\NetTiers.cst:行号 703
在 _CodeSmith.NetTiers_cst.Go() 位置 d:\myProject\NetTiers\NetTiers.cst:行号 1831
在 _CodeSmith.NetTiers_cst.__RenderMethod1(TextWriter writer, Control control) 位置 d:\myProject\NetTiers\NetTiers.cst:行号 5072
在 CodeSmith.Engine.Control.RenderChildren(TextWriter writer)
在 CodeSmith.Engine.CodeTemplate.Render(TextWriter writer)
在 CodeSmith.Engine.CodeTemplate.RenderToString()
在 CodeSmith.Engine.Remoting.TemplateSession.#Jpd()
在 System.Threading.Tasks.Task`1.InnerInvoke()
在 System.Threading.Tasks.Task.Execute()
Build complete -- 1 errors, 0 warnings
---------------------- Done ----------------------
Generation failed