对象必须实现 IConvertible 错误提示及解决方案

本文介绍了在使用gridControl控件时遇到的"对象必须实现IConvertible"错误,详细分析了该错误产生的原因,即数据类型转换错误和存储过程参数未赋值。重点讲述了问题出现在gridControl控件添加空白行并尝试保存到数据库时,由于内存大小限制导致的错误。提出了通过添加variableBindingSource作为过渡数据源来扩展内存空间,从而避免错误的解决方案。

如果出现以上错误。主要的原因有:
请检查数据类型转换过程有没有错误。就是说“=”两边的类型等。
还有就是存储过程中的参数,有可能你没给存储过程中的参数赋值等

以上是大佬的分析:分析原址

对于实际遇到的问题:gridControl控件添加空白行后 不能保存到数据库。

分析认为第二种的可能性更大。

为此,和老鸟们分析讨论解决了这个问题;

问题:
gridControl控件添加空白行后 不能保存到数据库。
通过属性设置添加空白行
添加的空白行 填值后,点新增或者保存到数据库,都会直接提示:对象必须实现 IConvertible 的错误提示

原因:

gridControl控件是通过绑定数据库为数据源的。绑定后,gridControl分配的内存空间是与数据库数据相同大小。当新增行且填值后,数据库的大小没有变,已经限定死。gridControl新增行属于超出了这个内存大小。所以报错。

解决方法:

通过给gridControl添加绑定一个过度用的数据源—>variableBindingSource
在这里插入图片描述
当gridControl控件新增行且填值后,variableBindingSource会同步扩大内存空间。再通过variableBindingSource与数据库作为绑定,将新增行添加到数据库。即可规避“对象必须实现 IConvertible ”的错误提示

System.InvalidCastException HResult=0x80004002 Message=无法将类型为“System.Windows.Controls.TextBox”的对象强制转换为类型“System.IConvertible”。 Source=mscorlib StackTrace: 在 System.Convert.ToDouble(Object value) 在 采样间隔和积分时间.MainWindow.RESET_Button_Click(Object sender, RoutedEventArgs e) 在 C:\Users\yinghao.fan\Desktop\采样间隔和积分时间\采样间隔和积分时间\MainWindow.xaml.cs 中: 第 31 行 在 System.Windows.RoutedEventHandlerInfo.InvokeHandler(Object target, RoutedEventArgs routedEventArgs) 在 System.Windows.EventRoute.InvokeHandlersImpl(Object source, RoutedEventArgs args, Boolean reRaised) 在 System.Windows.UIElement.RaiseEventImpl(DependencyObject sender, RoutedEventArgs args) 在 System.Windows.UIElement.RaiseEvent(RoutedEventArgs e) 在 System.Windows.Controls.Primitives.ButtonBase.OnClick() 在 System.Windows.Controls.Button.OnClick() 在 System.Windows.Controls.Primitives.ButtonBase.OnMouseLeftButtonUp(MouseButtonEventArgs e) 在 System.Windows.UIElement.OnMouseLeftButtonUpThunk(Object sender, MouseButtonEventArgs e) 在 System.Windows.Input.MouseButtonEventArgs.InvokeEventHandler(Delegate genericHandler, Object genericTarget) 在 System.Windows.RoutedEventArgs.InvokeHandler(Delegate handler, Object target) 在 System.Windows.RoutedEventHandlerInfo.InvokeHandler(Object target, RoutedEventArgs routedEventArgs) 在 System.Windows.EventRoute.InvokeHandlersImpl(Object source, RoutedEventArgs args, Boolean reRaised) 在 System.Windows.UIElement.ReRaiseEventAs(DependencyObject sender, RoutedEventArgs args, RoutedEvent newEvent) 在 System.Windows.UIElement.OnMouseUpThunk(Object sender, MouseButtonEventArgs e) 在 System.Windows.Input.MouseButtonEventArgs.InvokeEventHandler(Delegate genericHandler, Object genericTarget) 在 System.Windows.RoutedEventArgs.InvokeHandler(Delegate handler, Object target) 在 System.Windows.RoutedEventHandlerInfo.InvokeHandler(Object target, RoutedEventArgs routedEventArgs) 在 System.Windows.EventRoute.InvokeHandlersImpl(Object source, RoutedE
04-30
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值