请教“用户进程中发生浮点异常错误。已取消当前事务。”是怎么回事?还有一个关于unicode字符的问题!

cnhgj 2005-03-07 11:55:52
1、本来SQL SERVER好好的,今天突然出现“用户进程中发生浮点异常错误。已取消当前事务。”,后来将数据表对象复制表本地后,用相同的SQL语句查询正常!当查询分析器出现以上错误时,表的设计视图有无法打开。初步分析可能是库文件有损坏,如果真是库文件损坏,那么有哪些稳当处理方法。

2、insert into tb(fd) values (N'unicode字符')可以插入unicode字符,但如果当这些unicode是在参数里的话?那怎么办?
declare @t varchar(50)
set @t = 'unicode字符'
insert into tb(fd) values (@t)
...全文
640 37 打赏 收藏 转发到动态 举报
写回复
用AI写文章
37 条回复
切换为时间正序
请发表友善的回复…
发表回复
zjcxc 元老 2005-03-07
  • 打赏
  • 举报
回复
从上面的资料看,应该不属于sql的问题
zjcxc 元老 2005-03-07
  • 打赏
  • 举报
回复
错误号3628,严重级别24,用户进程中发生浮点异常错误。已取消当前事务。



严重级别 20 到 25
严重级别从 20 到 25 表明有系统问题。这是些严重错误,意味着进程(完成语句中指定任务的程序代码)将不再运行。进程在停止前先冻结,记录有关发生内容的信息,然后终止。到 SQL Server 的客户连接将关闭,并且根据存在问题的不同,客户端有可能无法重新连接。

严重级别为 19 或更高的错误信息将停止当前的批处理。严重级别为 20 或更高的错误信息被认为是严重错误,将终止客户连接。此范围的错误信息可能影响数据库中的所有进程,并可能表明数据库或对象损坏。严重级别从 19 到 25 的错误信息均写入错误日志。

cnhgj 2005-03-07
  • 打赏
  • 举报
回复
to zjcxc(邹建) ,重启过,无效
zjcxc 元老 2005-03-07
  • 打赏
  • 举报
回复
--第三个问题属于标准的树形处理问题

--树形数据查询示例
--作者: 邹建

if exists (select * from dbo.sysobjects where id = object_id(N'tb') and OBJECTPROPERTY(id, N'IsUserTable') = 1)
drop table tb
GO

--示例数据
create table tb(id int identity(1,1),pid int,name varchar(20))
insert tb select 0,'中国'
union all select 0,'美国'
union all select 0,'加拿大'
union all select 1,'北京'
union all select 1,'上海'
union all select 1,'江苏'
union all select 6,'苏州'
union all select 7,'常熟'
union all select 6,'南京'
union all select 6,'无锡'
union all select 2,'纽约'
union all select 2,'旧金山'
go

/*--树形数据处理

级别及排序字段

--邹建 2003-12(引用请保留此信息)--*/

/*--调用示例

--调用函数实现分级显示
select replicate('-',b.[level]*4)+a.name
from tb a,f_id()b
where a.id=b.id
order by b.sid
--*/
create function f_id()
returns @re table(id int,[level] int,sid varchar(8000))
as
begin
declare @l int
set @l=0
insert @re select id,@l,right(10000+id,4)
from tb where pid=0
while @@rowcount>0
begin
set @l=@l+1
insert @re select a.id,@l,b.sid+right(10000+a.id,4)
from tb a,@re b
where a.pid=b.id and b.[level]=@l-1
end
return
end
go

--调用函数实现分级显示
select a.*,tree=replicate('-',b.[level]*4)+a.name
from tb a,f_id()b
where a.id=b.id
order by b.sid
go

--删除测试
drop table tb
drop function f_id

/*--测试结果

id pid name tree
----------- ----------- -------------------- -------------------------
1 0 中国 中国
4 1 北京 ----北京
5 1 上海 ----上海
6 1 江苏 ----江苏
7 6 苏州 --------苏州
8 7 常熟 ------------常熟
9 6 南京 --------南京
10 6 无锡 --------无锡
2 0 美国 美国
11 2 纽约 ----纽约
12 2 旧金山 ----旧金山
3 0 加拿大 加拿大

(所影响的行数为 12 行)
--*/
zjcxc 元老 2005-03-07
  • 打赏
  • 举报
回复
第一个问题,记得是以前有人提到过的内存的问题,重启可以解决问题,下次遇到你试试重启

第二个问题,程序中定义的变量不能是unicode么? 没用过delphi,VB中的所有数据都用unicode类型,所以不存在这个问题,问题的关键还是在于我说的,在数据提交给数据库前,必须保证传递的数据是unicode类型,否则保存到数据库中的肯定不对(你总不能把坏苹果保存到好箱子中,要求苹果变为好苹果吧?)

Andy__Huang 2005-03-07
  • 打赏
  • 举报
回复
這個帖,這麼多星星,看都眼花了,還不解決嗎..........
cnhgj 2005-03-07
  • 打赏
  • 举报
回复
第一个问题搞不懂怎么回事,,我把表复制到本地,然后又复制回去就可以了。。。是否表里的残废的数据?在复制时修复了?
cnhgj 2005-03-07
  • 打赏
  • 举报
回复
ok,这个我试试。。然后其它两个问题请各位费心!
pbsql 2005-03-07
  • 打赏
  • 举报
回复
是的,你可以验证一下
cnhgj 2005-03-07
  • 打赏
  • 举报
回复
to pbsql(风云)
你的意思是在delphi中先指定unicode变量?
GXProgrammer 2005-03-07
  • 打赏
  • 举报
回复
不行。。
GXProgrammer 2005-03-07
  • 打赏
  • 举报
回复
declare @t table(dd nvarchar(50))
declare @test nvarchar(50)
set @test =N'š'
insert into @t values(@test)
insert into @t values(N'∮$Šš㈨')
select * from @t
cnhgj 2005-03-07
  • 打赏
  • 举报
回复
如果@t是存储过程中作为一个参数传进来的,那么相当于在开发工具中无法处理?
如果开发工具中只写sql语句,那么可以在字符串里加N,没问题
但如果parameters("dd").value := N'fdsf';这样肯定不行的啊。


顺便再问个问题,一个关于分类排序的问题
id name pid
1 中国 0
2 美国 0
3 英国 0
4 北京 1
5 华盛顿 2
6 伦敦 3
如何让它这样排?
id name pid
1 中国 0
4 北京 1
2 美国 0
5 华盛顿 2
3 英国 0
6 伦敦 3
也就是pid跟在前面的相同的id下面
zsms2 2005-03-07
  • 打赏
  • 举报
回复
听说SQL有病毒
zjcxc 元老 2005-03-07
  • 打赏
  • 举报
回复
楼主的图片处理在于,为变量赋值时,如果不指定N,则传输的是非unicode数据,保存之前就已经出错了
pbsql 2005-03-07
  • 打赏
  • 举报
回复
1.数据库没有问题,检查是哪部分程序引起的
2.widechar、widestring
zjcxc 元老 2005-03-07
  • 打赏
  • 举报
回复
第一个问题
你把数据库在服务器上复制一份,试试看看备份出的数据库有没有问题

另外,如果你的服务器没有停过机,试试关机重启,有可能是内存残骸导致的
zjcxc 元老 2005-03-07
  • 打赏
  • 举报
回复
delphi你是为delphi本身的变量赋值,不是为sql语句中的变量赋值,为sql中的变量赋值一样可以加N
cnhgj 2005-03-07
  • 打赏
  • 举报
回复
第一个问题大伙分析一下是否真的是库的问题。。已排除数据的问题。。因为整个对象已复制到本地执行正常
GXProgrammer 2005-03-07
  • 打赏
  • 举报
回复
BKMM又眼红了
加载更多回复(17)
 OpenGL-自主高性能三维GIS平台架构与实现/第二季:实现三维GIS球体+ 高程数据章节名称DEM基础1DEM基础知识1.介绍基本的DEM知识2.什么是DEM,作用是什么2DEM数据1.如何获取/ 传统测量/激光扫描/无人机测量/ 点云数据/ 倾斜摄影2.如何使用/局部小规模(栅格数据,图片/tif),3. 组织方式4. 根据使用目的不同,介绍多种优化方法3DEM图层的实现原理14DEM数据结构定义struct  V3U3N4顶点数据的生成和计算WGS84投影计算5wgs84 投影球体被切成一个个小圆弧,一共60个投影带,分别为01,02.........60WGS的最新版本为WGS 84(也称作WGS 1984、EPSG:4326),1984年定义、最后修订于2004年。接口定义坐标转换Wgs84 数据加载6瓦片编号计算生成算法1. 经纬度到大地坐标的转换2.大地坐标到经纬度坐标转换3. 根据经纬度获取瓦片编号框架重构7智能指针重构框架1. 基类定义(所有的类继承自基类),基类派生自 std::enbale_shared_from_this2. 实现智能指针的动态转换接口3. 实现向下转换4. 已有的类实现全部使用智能指针重构5. 任务系统(多线程加载任务)8引入图层(Layer)1. 介绍图层的概念以及重要性2. 图层类实现3. 修改框架(使用图层的方式重构框架)9Layer-bug排查(绘制过程出现错位,偶发)1. 框架重构后遇到问题(绘制结果错误)2. 瓦片索引方式发生变化,多线程引起内存问题3. 修改索引方式,解决绘制偶发错误问题10引入数据源(TileSource)1. 数据源的作用与设计目的2. 当前存在的问题,数据调度存在问题3. 数据源(TileSource)类实现11数据格式管理(FormatMgr)1. 数据格式管理(FormatMgr) 提出的目的,需要解决的问题2. CELLFormat基类接口抽象3. 实现几个标准格式类4. 修改框架流程,使用FormatMgr重构流程5. 扩展支持,后续支持任务格式数据加入系统12Task(任务)优化1. 任务低耦合数据结构,目的是让Task更加的通用2. 修改任务读取代码与任务处理代码,完善处理流程DEM高程13DEM-数字高程定义1. 什么是数字化高程数据2. 当下GIS系统有哪些常见的高程格式3. 课程体体系使用的哪种格式4. 高程类定义以及实现,并加入到FormatMgr 管理系统14高程瓦片数据读取1. 介绍GIS系统相关的工具(在数据转换)数据生成方面可以解决大量时间2. 自定义高程瓦片格式说明3. 自定义高程格式文件解析,并以智能对象的方式引入到系统4. 完善框架代码,适配高程数据15高程瓦片文件的读取1. 实现基本的读取算法2. 增加格式化组件,并加入到系统3. 配置高程图层以及高程数据源,并加载数据,验证数据正确性16瓦片数据结构重构1.顶点生成2.UV坐标计算3.面数据生成17DEM重构绘制流程1. 修改绘制数据结构,去除无用字段2. 增加Mesh类,实现光栅数据转换成三角面数据,计算UV数据,提炼接口3. 修改系统调度,实现顶点数据,UV数据,以及面数据的生成与更新4. 按需更新数据,而不是每一帧更新18DEM-数据精度问题(CPU)1. 因为瓦片数据使用大地坐标作为系统输入,造成瓦片坐标很大,单浮点数据精度不够2. 使用局部坐标的方式解决单浮点精度问题3. 调整相机参数,解决投影矩阵数据计算深度精度问题4. 修改绘制shader 实现对瓦片数据的绘制19DEM-数据精度问题(LogDepth)1. 使用对数深度(log depth )算法在GPU 计算解决单浮点经纬计算问题2. 修改shader ,增加对(logDepth)算法支持3. 修改C++端代码,实现对shader数据的输入20DEM-数据结构优化1.当下使用CPU端数据通过接口的方式传递给GPU,速度慢2. 使用Instance 方式降低Vertex Buffer 的大小,优化渲染系统21DEM-GPU缓冲区优化1. 使用Vertex Buffer Object / Index Buffer Object  / Instance  方式优化渲染系统2. 修改绘制接口,使用DrawElementsInstanceBaseInstance方式提升系统性能内存池与对象池22瓦片生成优化/对象池1. 相机移动过程会频繁的建立与释放瓦片,对CPU有较大的消耗2. 引入内存池,避免频繁的内存申请与释放,降低CPU时间3. 改造智能指针对象,对象释放通知到内存管理,回收对象内存23改造任务系统支持对象池1. 任务系统是一个公用模块,被多个模块使用,避免频繁的内存操作,引起的内存碎片2. 实现对象池,并应用到任务模块法线计算24法线计算1. 修改现有顶点结构,增加法线支持2. 修改shader,增加法线顶点输入,使用平行光光照模型3. 修改绘制流程,支持光照计算,使用探照灯作为光源输入25顶点法线计算/共享法线计算1. 增加数据结构保存顶点数据被多个面共享的次数2. 计算面法线,并累加到顶点法线3. 根据顶点被面共享的次数做平均法线计算4. 修改流程,按需更新法线数据26法线数据压缩1. 法线数据使用3 * float 数据存储,大大的增加了系统的数据2. 实现算法,将3 * float 数据压缩成4字节数据3. 改造绘制代码,支持压缩数据输入27GPU计算产生法线数据(去掉CPU计算)1. 引擎支持 Geometry Shader 阶段2. 编写 Geometry Shader,实现法线计算系统功能优化28重构CPU拾取流程1. 当下的拾取流程,只支撑二维数据拾取,无法准群的拾取三维数据2. Terrain增加拾取接口,输入射线,输出拾取到顶点数据29绘制拾取结果1. 增加一个绘制点的方法,实现绘制代码2. 修改shader,增加logdepth3. 调试代码,花费了很多时间排查错误,最总排查到是因为uniform参数笔误写错造成。30任务系统完善,避免任务队列无线膨胀1. 任务系统,没有限制队列的大小,生产者的能力远大于消费者的能力,造成任务队列膨胀2. 处理办法,限制生产者的生产能力,而不是限制任务队列大小(这种方式会造成业务逻辑异常复杂)3. 使用sleep休眠方式(这种方式是严重错误的)31如何避免瓦片数据抖动1. 产生瓦片抖动的原因 ? 分裂算法与回退算法间没有过度2. 引入过度流程,避免内存抖动,参数因子是一个重要的数据,需要谨慎使用3. 有必要结合瓦片自身数据动态计算参数因子32瓦片数据管理-fepk文件格式支持-全球数据加载1. 支持fepk文件格式,增加fepk读取组件,适配fepk文件2. fepk管理数据方式:一般情况选择全球前10级别作为基础级别,因数据量不大(1G)左右,后续以8级作为基础级别,全球19级别数据被划分为 2^8 * 2^7(512 * 256)个块。每个块包含了256 * 256 张小瓦片33fepk高程数据读取 34高程分裂处理当瓦片没有高程数据,那么子节点以及其他后代节点该如何共享父节点的数据35lesson-734-高程瓦片分裂处理(2)-算法实现高程数据分裂算法实现实现对高程数据的切分,并对特殊数据进行处理36高程瓦片分裂处理(3)-问题排查 37高程瓦片分裂处理(4)-(后代节点更新问题)当一个瓦片高程数据更新后,他的儿子节点,孙子节点...该如何处理?38瓦片视锥裁剪错误高程数据更新后,没有技术计算瓦片包围盒信息,造成包围盒错误,进而引视锥计算错误39http支持1.引入三方库 Libcurl2.http类封装,支持http读取数据40fepk.server使用 生成三维地球41改造四叉树-统一使用经纬度输入42地形网络生成算法重构 43引入球体坐标系 44使用球体坐标改造瓦片 45多图层(加载标签数据) 课时截图:镜头拉近后,显示细节数据加载矢量SHP国界线数据:加载矢量三维白膜数据截图高程数据加载点云数据 加载倾斜摄影数据 

34,594

社区成员

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

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