当某行数据有问题该如何调试?

bashen1101 2015-11-12 05:37:44
当一个表有几十万数据
用个自定义函数处理某列:
select uf_myFunc(col) from tb 

报错:
Msg 8114, Level 16, State 5, Line 258
从数据类型 nvarchar 转换为 float 时出错。


请问该如何用DEBUG快速定位到出错的数据?另有哪些方法?
...全文
172 9 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
9 条回复
切换为时间正序
请发表友善的回复…
发表回复
中国风 2015-11-30
  • 打赏
  • 举报
回复
select col from tb WHERE ISNUMERIC(col)=0
shoppo0505 2015-11-14
  • 打赏
  • 举报
回复
引用 2 楼 bashen1101 的回复:
[quote=引用 1 楼 shoppo0505 的回复:] 确定可能数据出问题? 那你用 select top 100 uf_myFunc(col) from tb 这种方式吧。 我猜测是uf_myFunc返回值类型和定义返回类型不匹配的缘故。
嗯,其实可以忽略具体问题,我想问的是解决此类问题的便捷方法。 比如我提出的例子,该函数对A字段好用,对B字段出错,那么显然差别在数据上,而如何从大量数据中迅速找到有问题的数据,这是我想问的。 你提供的方法是用2分法来查找,确实可以,也是我之前自己用的方法,不过这种手动方法总觉得有些别扭,所以想请教下大牛们有没有更好的方法。[/quote] 其实最好的方法是避免错误,对于数据操作,最根本的是首先要保证数据的可操作性。查找数据错误根源是本末倒置了。 如果要精确定位错误数据,那需要用游标这样的循环方式,而这个是在数据库操作中尽量避免的。不能把在编程语言中经验套用在数据库中。
zbdzjx 2015-11-13
  • 打赏
  • 举报
回复
能不能在自定义函数中进行处理,建一个表,如果在处理过程出错,将错误所在行存到表中,这样方便查。
bashen1101 2015-11-13
  • 打赏
  • 举报
回复
引用 3 楼 wangjinlong_wjl 的回复:
select col from tb WHERE ISNUMERIC(col) = 0 通过ISNUMERIC系统函数可以判断一下是否可以转换为数字,将不能转换为数字的行查出来进行处理就OK了
谢谢,是个方法,但好像仅仅限于某些具体问题,若是自定义函数报其它类型错误也许就不适用了。 我想知道SQLSERVER的DEBUG能否做到行的级别。这样在调试自定义函数时可以迅速定位问题。
Yole 2015-11-13
  • 打赏
  • 举报
回复
我关注这样的问题也好久了~~ 您可以试试把数据导出excel,然后把那列转成小数格式。看表格也许会快些~~~
江南雪_158 2015-11-13
  • 打赏
  • 举报
回复
select col from tb WHERE ISNUMERIC(col) = 0 通过ISNUMERIC系统函数可以判断一下是否可以转换为数字,将不能转换为数字的行查出来进行处理就OK了
bashen1101 2015-11-13
  • 打赏
  • 举报
回复
引用 1 楼 shoppo0505 的回复:
确定可能数据出问题? 那你用 select top 100 uf_myFunc(col) from tb 这种方式吧。 我猜测是uf_myFunc返回值类型和定义返回类型不匹配的缘故。
嗯,其实可以忽略具体问题,我想问的是解决此类问题的便捷方法。 比如我提出的例子,该函数对A字段好用,对B字段出错,那么显然差别在数据上,而如何从大量数据中迅速找到有问题的数据,这是我想问的。 你提供的方法是用2分法来查找,确实可以,也是我之前自己用的方法,不过这种手动方法总觉得有些别扭,所以想请教下大牛们有没有更好的方法。
bashen1101 2015-11-13
  • 打赏
  • 举报
回复
引用 6 楼 zbdzjx 的回复:
能不能在自定义函数中进行处理,建一个表,如果在处理过程出错,将错误所在行存到表中,这样方便查。
函数里有限制,无法进行增删改,连print都不行
shoppo0505 2015-11-12
  • 打赏
  • 举报
回复
确定可能数据出问题? 那你用 select top 100 uf_myFunc(col) from tb 这种方式吧。 我猜测是uf_myFunc返回值类型和定义返回类型不匹配的缘故。
Visual Studio Code 是由微软开发的一款免费、开源、跨平台的现代化轻量级代码编辑器,自发布以来迅速成为全球开发者最受欢迎的工具之一。它结合了编辑器的轻便性和集成开发环境(IDE)的强大功能,支持多种编程语言和开发场景,核心特点: 1. 跨平台支持 可在 Windows、macOS 和 Linux 上运行,保持一致的用户体验。 2. 轻量级与高性能 启动速度快,占用资源少,适合处理大型项目或低配置设备。 3. 智能代码补全 内置 IntelliSense(智能感知),提供代码提示、参数信息、快速修复等功能,支持 JavaScript、TypeScript、Python、C++ 等主流语言。 4. 内置终端 直接在编辑器内打开集成终端(支持 PowerShell、CMD、Bash 等),方便执行命令行操作。 5. 调试工具 内置调试器,支持断点、变量监视、调用堆栈查看等,无需离开编辑器即可调试代码。 6. Git 集成 直接通过侧边栏管理 Git 仓库,支持提交、分支切换、冲突解决等操作。 7. 丰富的扩展生态系统 通过 Extensions Marketplace 可安装数千款插件,扩展功能包括: 语言支持:如 Java、Go、Rust 等。 主题与图标:自定义界面风格。 工具集成:如 Docker、Kubernetes、数据库连接等。 效率工具:如 REST Client、Live Server 等。 8. 自定义与主题 支持修改键盘快捷键、界面主题、文件图标等,打造个性化开发环境。 9. 多光标编辑 按住 Alt(Windows/Linux)或 Option(macOS)点击可添加多个光标,同时编辑多处代码。 10. 远程开发支持 通过 Remote - SSH、Remote - Containers 等扩展,可直接连接远程服务器或开发容器,实现无缝协作。

34,837

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
  • 基础类社区
  • 二月十六
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧