【解决】CodeSmith 7 执行出错 《无法将类型为“System.Int32”的对象强制转换为类型“System.String”》

22 篇文章 0 订阅
1 篇文章 0 订阅

今天突然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
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值