新人求助:SQL server 2008中用触发器创建复杂的公式(参数引用其它表中数据),出问题,求指点

aaaa1185164 2015-08-31 02:35:50
[size=18px][b]有两个表,一个是JGDCB,一个是二元形高参数表;表JGDCB中存储:每公顷断面积、胸径、树高、树种、蓄积量;二元形高参数表中存储:树种,a,b,c(abc为不同树种的参数值);
现在创建了一个触发器,希望输入每公顷断面积、胸径、树高和树种后,自动计算得到蓄积量,公式如下
每公顷蓄积=每公顷断面积*a*树高的b次方/胸径的c 次方
a,b,c 存储在二元形高参数表里,,,根据树种不同,a,b,c参数取值不同,
创建的触发器如下
触发器如下
create trigger JGB_tri
on JGDCB
for insert
as
begin transaction
update JGDCB
set 每公顷蓄积 = 每公顷断面积*(selecta from 二元形高参数表)*power(树高,(select b from 二元形高参数表))/power(胸径,(select c from 二元形高参数表))
where EXISTS ( select a,b,c from 二元形高参数表 where JGDCB.树种 = 二元形高参数表.树种名称)
commit transaction
可以保存,但是在运行输入的时候,出现错误查询返回的值不止一个当子查询跟随在 =、!=、<、<=、>、>= 之后,或子查询用作表达式时,这种情况是不允许的。

初学者,现学现卖,遇到问题很多,,求教大神,使用触发器是否是实现此计算功能较好的方法?还有啥方法?我做触发器问题出在哪?
新人分数不多,还请各位大神不吝赐教,,,,,拜谢
...全文
285 14 打赏 收藏 转发到动态 举报
写回复
用AI写文章
14 条回复
切换为时间正序
请发表友善的回复…
发表回复
aaaa1185164 2015-09-03
  • 打赏
  • 举报
回复
引用 11 楼 Tiger_Zhao 的回复:
EXCEL 中小数都是按浮点双精度运算的,所以你应该统一转换为float运算,结果保存在 numeric(4,1) 字段中没关系。
哈哈,问题终于解决了,还是要转换成float型,一开始是我转换有问题 。。。。。 cast(i.每公顷断面积 as float)*cast(p.a as float)*power(cast(i.树高 as float),cast(p.b as float))/power(cast(i.胸径 as float),cast(p.c as float)) AS 每公顷蓄积 。。。。。 这样就正确了, 感谢,非常感谢
Tiger_Zhao 2015-09-02
  • 打赏
  • 举报
回复
EXCEL 中小数都是按浮点双精度运算的,所以你应该统一转换为float运算,结果保存在 numeric(4,1) 字段中没关系。
aaaa1185164 2015-09-02
  • 打赏
  • 举报
回复
引用 11 楼 Tiger_Zhao 的回复:
EXCEL 中小数都是按浮点双精度运算的,所以你应该统一转换为float运算,结果保存在 numeric(4,1) 字段中没关系。
........ SELECT i.ID, cast(i.每公顷断面积 as float)*cast(p.a as float)*cast(power(i.树高,p.b) as float)/cast(power(i.胸径,p.c) as float) AS 每公顷蓄积 FROM inserted i JOIN CSB p ON i.树种 = p.树种 ......... 用cast,进行了转换,结果还是不对,跟没转化是一样的,,,,到底哪里出问题了呢?唉,, ps.已经确定不是a,b,c参数的问题,重新建了一个表只输入了一种树一个参数,结果还是没变,,跟excel算的不一样
gw6328 2015-09-02
  • 打赏
  • 举报
回复
如果公式一定,可以不必用触发器,用计算列,或者程序用的时候再计算都可以。
aaaa1185164 2015-09-01
  • 打赏
  • 举报
回复
求助,,,大神求指点,,,
aaaa1185164 2015-09-01
  • 打赏
  • 举报
回复
不全是,参数表中a,b,c几个参数都是小数例如0.763610635,这样的,,,树高设的是保留一位小数numeric(3,1),胸径是整数,然后最后求出的蓄积要求一位小数,根据实际出现的数值大小我设置为numeric(4,1),数据类型是不是挺乱,这样不能直接运算吗,,,,初学者现学现卖,小问题比较多,十分感谢指教,,,,
Neo_whl 2015-09-01
  • 打赏
  • 举报
回复
引用
朋友你好,你提供的方法非常有效,运行没有问题,输入也没有问题,但是,相同的公式和参数,在SQL server 2008这个表格里运行算出来的结果,跟我用excel算出来的结果不一样啊,差很大,好奇怪,这可能是啥问题,,,,,,ps.不同树种对应的a,b,c参数不同,已经在二元形高参数表中按照树种名称依次列出,在JGDCB中输入的树种名是二元形高参数表中已经存在的树种名称
差别很大?没有测试数据,不太清楚你存储数据的数据类型,可能是整数取整问题造成的差异。
Tiger_Zhao 2015-09-01
  • 打赏
  • 举报
回复
你的数据都是整数?
SQL 中 整数/整数 是整除,前面再乘个1.0变成小数除 1.0*整数/整数
aaaa1185164 2015-09-01
  • 打赏
  • 举报
回复
引用 6 楼 Tiger_Zhao 的回复:
p.power 这里去掉。 如果已经有10000条,都是已经算好的。 插入1条后没必要把10001条更新一遍,只要更新新插入的那一条就可以了。
大神你好,给的代码好长时间才看懂,厉害呀,现在更正后可以实现计算,但是遇到了跟四楼一样的问题,,,就是SQL SERVER表中算出来的值跟excel表中相同参数相同公式算出来的值不一样,我已经检查好几遍参数,每个树种对应输入的a,b,c三个参数没有啥问题,,,,这是什么原因,大神是否有解决方法,,,
Tiger_Zhao 2015-09-01
  • 打赏
  • 举报
回复
p.power 这里去掉。

如果已经有10000条,都是已经算好的。
插入1条后没必要把10001条更新一遍,只要更新新插入的那一条就可以了。
aaaa1185164 2015-09-01
  • 打赏
  • 举报
回复
引用 3 楼 Tiger_Zhao 的回复:
...
UPDATE JGDCB
SET JGDCB.每公顷蓄积 = t.每公顷蓄积
FROM JGDCB,
(
SELECT i.ID,
i.每公顷断面积*p.power(i.树高,p.b)/power(i.胸径,p.c) AS 每公顷蓄积
FROM inserted i
JOIN 二元形高参数表 p
ON i.树种 = p.树种名称
) t
WHERE JGDCB.ID = t.ID
...

只更新插入相关的,不要全表更新。

出现一个问题,如下图
朋友你的意思是输入一条记录更新一下蓄积,不能其它参数输入后一次更新所有蓄积
aaaa1185164 2015-09-01
  • 打赏
  • 举报
回复
引用 2 楼 u011015550 的回复:

--试试这样
create trigger JGB_tri
on JGDCB
for insert
as
begin transaction
update JGDCB
set 每公顷蓄积 = 每公顷断面积*tb2.a*power(树高,tb2.b)/power(胸径,tb2.c)
from 二元形高参数表 as tb2 join JGDCB on JGDCB.树种=tb2.树种
commit transaction
朋友你好,你提供的方法非常有效,运行没有问题,输入也没有问题,但是,相同的公式和参数,在SQL server 2008这个表格里运行算出来的结果,跟我用excel算出来的结果不一样啊,差很大,好奇怪,这可能是啥问题,,,,,,ps.不同树种对应的a,b,c参数不同,已经在二元形高参数表中按照树种名称依次列出,在JGDCB中输入的树种名是二元形高参数表中已经存在的树种名称
Tiger_Zhao 2015-09-01
  • 打赏
  • 举报
回复
...
UPDATE JGDCB
SET JGDCB.每公顷蓄积 = t.每公顷蓄积
FROM JGDCB,
(
SELECT i.ID,
i.每公顷断面积*p.power(i.树高,p.b)/power(i.胸径,p.c) AS 每公顷蓄积
FROM inserted i
JOIN 二元形高参数表 p
ON i.树种 = p.树种名称
) t
WHERE JGDCB.ID = t.ID
...

只更新插入相关的,不要全表更新。
Neo_whl 2015-09-01
  • 打赏
  • 举报
回复

--试试这样
create trigger JGB_tri
on JGDCB
for insert
as
begin transaction
update JGDCB
set 每公顷蓄积 = 每公顷断面积*tb2.a*power(树高,tb2.b)/power(胸径,tb2.c)
from 二元形高参数表 as tb2 join JGDCB on JGDCB.树种=tb2.树种
commit transaction
SQL Server 2005微软官方权威参考手册     是Inside Microsoft SQL Server 2005系列书中的第一本,SQL Server类的顶尖之作   全球公认SQL Server 2005经典著作,囊括大量鲜为人知的技术内幕,大师智慧、专家经验尽览无余。       本系列图书中文版得到了微软总部SQL Server组专家的高度重视,同时也得到了微软中国上海SQL Server全球技术支持中心的高度关注。        本书详细介绍了T-SQL的内部构造,包含了非常全面的编程参考。数据库开发人员和DBA可以通过书中的最佳实践、高级技巧和代码示例来掌握这门复杂的编程语言,以切合实际的方案来解决复杂问题。本书涵盖了T-SQL程序设计的方方面面,如基于集合的编程技术、日期和时间相关的XML和CLR数据类型的使用、临时对象、T-SQL和CLR用户自定义函数、存储过程、触发器、事务和新的错误处理结构、应用并发模型支持并发用户、使用Service Broker来控制数据库应用程序中的异步处理等。   内容简介 本书是Inside Microsoft SQL Server 2005系列四本著作中的一本。它详细介绍了T-SQL的内部构造,包含了非常全面的编程参考。它提供了使用Transact-SQL(T-SQL)的专家级指导,T-SQL是用于SQL Server的最常见的也是功能最强大的编程语言。该书由Itzik Ben-Gan权威执笔,重点关注语言特性以及它们如何被SQL Server引擎解释和处理。   通过本书,你将深入了解T-SQL的高级用法,包括触发器、用户自定义函数、异常处理等。该书解释并比较了SQL Server 2000和SQL Server 2005在数据库开发相关问题上的解决方案,深入讨论了SQL Server 2005中新增的T-SQL编程特性,包含了大量的代码示例、表示例和逻辑难题以帮助数据库开发人员和管理员理解复杂的逻辑并掌握T-SQL。   本书适合于专业数据库开发者、BI开发者、DBA和以SQL Server作为后台数据库的一般应用程序开发者,读者可以通过书中的最佳实践、高级技巧和代码示例来掌握这门复杂的编程语言,以切合实际的方案来解决复杂的实际问题。 作者简介 Itzik Ben-Gan是Solid Quality Learning的导师和创始人。从1999年开始,他一直是Microsoft SQL Server MVP(最有价值专家),并在全世界已经开展过无数次T-SQL查询、T-SQL优化和编程方面的培训。Itzik是Microsoft SQL Server方面几本著作的作者。他在SQL ServerMagazine和MSDN上发表了许多文章和白皮书。Itzik被邀请在许多会议上做报告,包括TechEd、DevWeek、世界各地的各种SQL用户组、PASS、SQL server Magazine Connections和Solid Quality Learning的会议。 从1992年开始,Itzik就一直致力于涉及各种数据库和计算机系统相关技术的多个课题。除了帮助顾客处理紧迫的要、修复问题、优化数据库、教学和担任顾问以外,他还帮助开发人员和数据库管理员转变关系/基于集合的理念,改善他们编写代码的性能和可维护性。Itzik擅长T-SQL查询、查询优化、编程和内部原理,此外他还精通其他的数据库领域。1999年,Itzik创立以色列SQL Server和OLAP用户组,一直管理至今。 目录 序 前言 致谢 引言 第1章 数据类型相关的问题,XML和CLR UDT 1.1 DATETIME数据类型 DATETIME的存储格式 时间处理   Datetime相关的查询问题  1.2 与字符相关的问题   模式匹配   区分大小写(Case-Sensitive)的筛选器  1.3 大型对象(Large Object,LOB)   MAX 说明符   BULK行集提供程序  1.4 隐式转换(Implicit Conversion)   标量表达式   筛选表达式  1.5 基于CLR的用户定义类型   UDT理论简介   开发UDT  1.6 XML数据类型   关系数据库中的XML支持   什么时候应该使用XML代替关系表现形式?   数据库中的XML序列化对象   使用开放架构(Open Schema)的XML   作为存储过程参数的XML数据类型   Xquery修改语句  1.7 结论 第2章 临时表和表变量  2.1 临时表   局部临时表   全局临时表  2.2 表变量   限制条件   tempdb   范围和可见性   事务上下文   统计信息  2.3 tempdb相关的注意事项  2.4 表表达式  2.5 比较临时对象  2.6 综合练习——关系分区(Relational Division)  2.7 结论 第3章 游标  3.1 使用游标  3.2 游标开销  3.3 单独处理每一行  3.4 按顺序访问   自定义聚合   连续聚合   最大并发会话   匹配问题  3.5 结论 第4章 动态SQL 第5章 视图 第6章 用户定义函数 第7章 存储过程 第8章 触发器 第9章 事务 第10章 错误处理 第11章 Service Broker 附录A CLR程序指南 A.1 创建CLRUtilities数据库: SQL Server A.2 部署:Visual Studio A.3 部署和测试:Visual Studio 和 SQL Server 索引 中英文术语对照表

22,295

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server 疑难问题
社区管理员
  • 疑难问题社区
  • 尘觉
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

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