asp.net 復雜sql查詢

sujunjun 2012-03-29 11:30:48

有3個數據庫DB_A,DB_B,DB_C,分別有相同結構的表A

表A有字段:a 員工序號,b 薪資序號,c 加減代號,d 金額

條件:比較DB_A,DB_B表A金額匯總的大小,然后將金額大的記錄導入到DB_C的表A

例如:DB_A:表A: 1為加項 2,3為減項

YG_01 01 1 100
YG_01 03 1 100
YG_01 02 2 20

例如:DB_B:表A:

YG_01 01 1 500
YG_01 03 3 200
YG_01 05 1 300

DB_A金額為:180,DB_B金額:600,結果就是將DB_B的三條記錄導入DB_C的表A中
...全文
262 16 打赏 收藏 转发到动态 举报
写回复
用AI写文章
16 条回复
切换为时间正序
请发表友善的回复…
发表回复
sujunjun 2012-04-01
  • 打赏
  • 举报
回复
有3个数据库 DB_A,DB_B,DB_C,分別有相同结构的表A

表A有字段:a 员工代号,b 薪资代号,c 加減代代,d 金額,y 年月

条件:按2012-4-1比较DB_A,DB_B中表A相同员工金额汇总的大小,
然后將汇总金额较大的明细导入到DB_C的表A

例如:DB_A:表A: 1为加项 2,3为減项

YG_01 01 1 600 2012-3-1
YG_01 03 3 500 2012-3-1
YG_01 05 1 300 2012-3-1
YG_01 01 1 100 2012-4-1
YG_01 03 1 100 2012-4-1
YG_01 02 2 20 2012-4-1
YG_02 01 1 50 2012-4-1
。。。。。。。。

例如:DB_B:表A:

YG_01 01 1 500 2012-4-1
YG_01 03 3 200 2012-4-1
YG_01 05 1 300 2012-4-1
YG_02 01 1 20 2012-4-1

结果:
select * from DB_C.DBO.表A
YG_01 01 1 500
YG_01 03 3 200
YG_01 05 1 300
YG_02 01 1 50
zllllz1 2012-04-01
  • 打赏
  • 举报
回复
能不能打简体字!
Mirror然 2012-04-01
  • 打赏
  • 举报
回复
能换简体字不 直接写数据 想要的结果
看起来还累
  • 打赏
  • 举报
回复
[Quote=引用 10 楼 的回复:]

引用 8 楼 的回复:
引用楼主 的回复:

例如:DB_A:表A: 1為加項 2,3為減項

YG_01 01 1 1……

不怎么明白你的意思。你这说的很模糊,真的是仅仅把將DB……


謝謝你的回復!還有不明確的?你沒有考慮按員工代號分組,其它都差不多
這種寫法可能復雜度有點高
[/Quote]

你给出你说的情况的测试数据和对应结果。不要用繁体字
这个确实看起来很多内容,但是从算法上分析并不复杂,你要想简单,建议使用存储过程
sujunjun 2012-04-01
  • 打赏
  • 举报
回复
[Quote=引用 8 楼 的回复:]
引用楼主 的回复:

例如:DB_A:表A: 1為加項 2,3為減項

YG_01 01 1 1……

不怎么明白你的意思。你这说的很模糊,真的是仅仅把將DB……
[/Quote]

謝謝你的回復!還有不明確的?你沒有考慮按員工代號分組,其它都差不多
這種寫法可能復雜度有點高
w990824403 2012-04-01
  • 打赏
  • 举报
回复
declare @Res varchar(10)
select @Res =
case when ((select ((select sum(d) from DB_A where c='1')-(select sum(d) from DB_A where c in('2','3')))) > (select ((select sum(d) from DB_B where c='1')-(select sum(d) from DB_B where c in('2','3')))) )
then
'A大于B'
else
'B大于A'
end
select @Res
判断完后直接插入就可以了
insert into DB_C select * from DB_A
或insert into DB_C select * from DB_B
yyz985 2012-04-01
  • 打赏
  • 举报
回复
1.把数据复制到剪贴板
--paste
--filter NY=#2012-4-1#
--v2t
--group yg,DH,LX;JE=max(child.JE)
--sort YG,DH

结果:
YG DH LX JE
YG_01 01 1 500
YG_01 02 2 20
YG_01 03 1 100
YG_01 03 3 200
YG_01 05 1 300
YG_02 01 1 50

http://blog.csdn.net/yyz985/article/details/7400360

数据:
YG DH LX JE NY
YG_01 01 1 600 2012-3-1
YG_01 03 3 500 2012-3-1
YG_01 05 1 300 2012-3-1
YG_01 01 1 100 2012-4-1
YG_01 03 1 100 2012-4-1
YG_01 02 2 20 2012-4-1
YG_02 01 1 50 2012-4-1
YG_01 01 1 500 2012-4-1
YG_01 03 3 200 2012-4-1
YG_01 05 1 300 2012-4-1
YG_02 01 1 20 2012-4-1
  • 打赏
  • 举报
回复

--> 测试数据:[表A]
DB_A
if object_id('[表A]') is not null drop table [表A]
create table [表A]([BH] varchar(5),[ID] varchar(2),[LX] int,[VALUE] int)
insert [表A]
select 'YG_01','01',1,100 union all
select 'YG_01','03',1,100 union all
select 'YG_01','02',2,20
--DB_B
--> 测试数据:[表B]
if object_id('[表B]') is not null drop table [表B]
create table [表B]([BH] varchar(5),[ID] varchar(2),[LX] int,[VALUE] int)
insert [表B]
select 'YG_01','01',1,500 union all
select 'YG_01','03',3,200 union all
select 'YG_01','05',1,300
--DB_C
if object_id('[表C]') is not null drop table [表C]
create table [表C]([BH] varchar(5),[ID] varchar(2),[LX] int,[VALUE] int)


INSERT DB_C..[表C]
SELECT DISTINCT
case WHEN(select SUM(case when lx=1 then [VALUE] else -[VALUE] end) from DB_A..[表A])
-(select SUM(case when lx=1 then [VALUE] else -[VALUE] end) from DB_B..[表B])>0
then A.BH else B.BH END,
case WHEN(select SUM(case when lx=1 then [VALUE] else -[VALUE] end) from DB_A..[表A])
-(select SUM(case when lx=1 then [VALUE] else -[VALUE] end) from DB_B..[表B])>0
then A.ID else B.ID END,
case WHEN(select SUM(case when lx=1 then [VALUE] else -[VALUE] end) from DB_A..[表A])
-(select SUM(case when lx=1 then [VALUE] else -[VALUE] end) from DB_B..[表B])>0
then A.LX else B.LX END,
case WHEN(select SUM(case when lx=1 then [VALUE] else -[VALUE] end) from DB_A..[表A])
-(select SUM(case when lx=1 then [VALUE] else -[VALUE] end) from DB_B..[表B])>0
then A.[VALUE] else B.[VALUE] END FROM DB_A..[表A] A,DB_B..[表B] B

SELECT * FROM DB_B..[表C]
/*
BH ID LX VALUE
YG_01 01 1 500
YG_01 03 3 200
YG_01 05 1 300
*/
  • 打赏
  • 举报
回复
[Quote=引用楼主 的回复:]
有3個數據庫DB_A,DB_B,DB_C,分別有相同結構的表A

表A有字段:a 員工序號,b 薪資序號,c 加減代號,d 金額

條件:比較DB_A,DB_B表A金額匯總的大小,然后將金額大的記錄導入到DB_C的表A

例如:DB_A:表A: 1為加項 2,3為減項

YG_01 01 1 1……
[/Quote]
不怎么明白你的意思。你这说的很模糊,真的是仅仅把將DB_B的三條記錄導入DB_C的表A中,那很容易实现
但是这又跟数据库DB_A有什么关系,跟他们的DB_A金額為:180,DB_B金額:600有什么关系?
解释清楚点
sujunjun 2012-03-31
  • 打赏
  • 举报
回复
有没有人通过一条SQL语句解决,高手指点!
sujunjun 2012-03-29
  • 打赏
  • 举报
回复
有沒有高手解答啊
sujunjun 2012-03-29
  • 打赏
  • 举报
回复
這樣做是可以,我以為還有更好的方法可以實現
觉悟之时 2012-03-29
  • 打赏
  • 举报
回复
declare @totalA int ,
declare @totalB int
select @totalA=sum(金额) from DB_A:表A
select @totalB=sum(金额) from DB_B:表B
if(@totalA>@totalB)
begin
INSERT INTO DB_C(PriKey, Description)
SELECT ForeignKey, Description
FROM DB_A;
end
else
begin
INSERT INTO DB_C(PriKey, Description)
SELECT ForeignKey, Description
FROM DB_B;
end

类似如此,你对应的改改就是的了 。
hanguoji84 2012-03-29
  • 打赏
  • 举报
回复
用存储过程处理吧,复杂一些。
sujunjun 2012-03-29
  • 打赏
  • 举报
回复
SQL語句實現啊,將查詢的語句插入到表中。
Lugyedo 2012-03-29
  • 打赏
  • 举报
回复
要用sql语句实现呢,还是C#代码实现?
.Net精品就业班课程表 : 1、.Net基础加强(10天) 核心技术课程 常用数据结构(List、Dictionary、Array)、多态、常用设计模式、反射、常用.net类库、泛型、IO流、委托事件、正则表达式、XML、反射、GC等。 2、数据库开发及ADO.Net(6天) 核心技术课程 数据库开发基础、Microsoft SQLServer基础、SQL语言基础、索引、事务、SQL语言高级技术(空值处理、聚合与分组、数据分页、Union、日期函数、类型转换函数、流控函数、表连接、子查询、存储过程、触发器)、数据库设计范式、数据库调优。 ADO.Net(行集、数据集、类型化数据集、SQLHelper、SQL注入漏洞防范、数据绑定)。 3、三层架构MIS项目(5天) 查看项目演示 功能点 本项目基于流行的三层架构(DAL+BLL+UI)。 主要功能点:高安全性的用户管理体系、高安全性的异构系统数据导入导出、拼音检索、复合检索、无限级次数据管理、个性化邮件群发、Excel文件导入导出。 技术点 ADO.Net技术应用、SQLServer、MD5安全算法、基于NPOI的Excel文件处理、树状结构数据处理、递归、CodeSmith、代码生成器、三层架构。 项目说明 这是一个用WinForm技术实现的系统,传智播客在开课的半个月就安排一个项目,体现了传智播客“项目驱动学习”的先进教学理念。 4、网页开发与JavaScript(7天) 查看案例演示 核心技术课程 HTML基础加强、css(包含Div+CSS布局)、JavaScript、Dom(事件、window对象、document对象、对话框、定时器、粘贴板、动态Dom、跨浏览器兼容性解决方案、JS压缩和CDN、Internet Explorer Developer Toolbar)、JQuery(JQuery函数、隐式迭代、链式编程、id选择器、tag选择器、CSS选择器、层次选择器、表单选择器、过滤选择器、复合选择器、节点导航、节点操作、样式操作、事件、动画、JQuery Cookie、JQuery Live、JQueryUI)。 课程说明 CSS、JavaScript是ASP.Net开发的基础,把这些掌握好了就能很轻松的学会ASP.Net;Dom是实现网页动态效果的技术,在网站越来越个性化年代,招聘企业对应聘者的Dom水平要求非常高;JQuery是近几年异军突起的JavaScript框架库,几乎成了Web前端开发事实上的标准,大部分企业都是使用JQuery进行Web前端的开发。 学完了这阶段课程,学员将学会开发主流网站的前端效果,比如:焦点图、滚动展示图、网页防复制、网页自定义菜单、WebOS、美女时钟、无刷新评论、评分控件、表格特效、图片悬浮详细信息、微博界面、QQ消息框效果、Div对话框等。 5、ASP.Net开发(12天) 核心技术课程 自己动手写Web服务器(Socket、多线程)、ashx模式Web开发、ViewState、Cookie、Session、Http协议、Web开发基本原则、XSS漏洞防范、Request对象、Response对象、Server对象、虚拟路径、HttpHandler深入、ASP.Net生命周期、WebForm原理、服务端基本控件、WebShell漏洞防范、HTML服务端控件、验证框架、MasterPage、数据绑定控件(ObjectDataSource、列表类绑定控件、GridView、FormView、ListView、Repeater、高效率分页)、CKEditor、Membership、缓存、互联网调优(SEO、HTML压缩、页面静态化、移除ViewState、表单GET化)、URL重写、错误处理、AJAX(XMLHTTP、JQuery AJAX、Json)、全局文件、HttpHandler与HttpModule、IIS配置。 课程说明 由于微软对ASP.Net进行高度封装,因此ASP.Net入门非常简单,开发人员不需要了解HTML、JavaScript、Http协议也可以快速开发出一个Web系统,正因为如此,社会上充斥着大量这样的“拖控件的开发人员”,使得很多Java、PHP等语言的开发人员诋毁ASP.Net开发人员的时候经常会说“你们什么都不懂,就会拖控件”。ASP.Net的快速开发是ASP.Net非常大的一个优点,可以加快开发效率,这是行业的发展趋势,但是局限于这样的“傻瓜化开发方式”的开发人员的竞争力和成长性都是非常有限的,遇到ASP.Net一些高级技术(比如ASP.Net MVC、SEO、网站调优、服务端客户端混合编程、AJAX等)的时候就完全不能胜任。通过上一个阶段的HTML、JavaScript、Dom的学习,学员已经有了很好的HTML、JavaScript基础;在ASP.Net课程的一开始,不是直接教学员怎么拖ASP.Net控件进行快速开发,而是通过ashx的模式开发原始的动态网站,让学员明白“请求—处理—响应模型”、“Http协议、Http无状态”、“c#代码渲染生成浏览器端JavaScript”、“ViewState的作用”、“Session的原理”等这些基本而又重要的原理,从而扫清后面ASP.Net知识学习的基础性障碍。 由于访问量非常大,因此互联网项目的开发对ASP.Net开发人员的要求非常高,所以我们安排了互联网调优、缓存、网站防黑等内容。 ASP.Net中控件数量是非常多的,讲解ASP.Net的教材通常要上千页,让初学者望而生畏,其实ASP.Net大部分控件相似性非常强的,同类型的控件学会了一个那么其他控件也就很容易学会了。比如只要学会了DropDownList,那么RadioButtonList、ListBox、CheckBoxList、BulletedList等几乎不用学就会用;再比如只要学会了ListView,那么Repeater、GridView、FormView等控件也是触类旁通。传智播客认真钻研教学,对知识进行分类、整理、提炼精华,让学员在短时间内掌握ASP.Net技术。 ASP.Net中有一些技术是有局限性的,传智播客根据这些技术在企业中的实际应用情况进行了调整、补充。比如项目中几乎没有在UI层直接访问数据库的,而是采用三层架构,因此我们不讲解UI层直连数据库的控件SQLDataSource,而是把主要精力放在讲解三层架构开发模式。再比如ASP.Net内置的AJAX解决方案UpdatePanel只在部分要求不高的内网项目中才被使用,因此我们在讲解UpdatePanel的使用和原理之外,把更多的时间放在讲解企业中用的最多的JQuery AJAX解决方案上。 6、B/S系统项目(7天) 项目说明 1、网上图书商城。这是一个典型的B2C网上商城,使用经典的复杂三层架构(工厂模式)进行开发。涉及图书管理、搜索、订单管理、导航管理等核心模块。在讲解ASP.Net基础后安排这样一个B2C网上商城系统,让学员在实际项目中将学到的知识学以致用。 2、办公自动化OA系统。这是一个典型的基于ASP.Net技术的OA协同办公项目,包含了权限管理、公告管理、文档管理、工作流、论坛管理、新闻模块管理、人员管理等典型的OA系统模块。 3、数据采集和邮件群发。这是一个基于多线程的邮件营销平台,核心技术包括网络爬虫、多线程、HTML解析、邮件发送、生产者消费者模式等。 注:以上三个案例,上课时会根据每个班的课堂反馈选择其中一个案例予以讲解学习。 7、如鹏网项目(9天) 查看项目演示 功能点 站内搜索、栏目管理、视频播放(完全模仿优酷视频页面)、焦点图、静态页面生成(新浪、搜狐等大型网站普遍采用的技术)、文章管理、无刷新评论、评论的无刷新分页、敏感词过滤、用户管理、友情链接管理、缓存管理、广告位管理、RSS输出、水印设置、无刷新上传图片、搜索引擎优化设置、数据备份恢复、伪静态设置、网上商城、订单管理、在线支付(支持支付宝、财付通、块钱等第三方支付平台)、网站调优(数据库优化、缓存、静态页、CSS Spirit、js压缩)。 技术点 搜索引擎技术:Lucene.Net、多线程开发、爬虫技术、网页分析、正则表达式、Log4Net日志框架、Quartz.Net定时作业调度。 大型互联网开发技术:代码生成、网页静态化、基于JQuery的Web2.0页面开发、AJAX、SEO、网站调优、采集器、RSS/XML、网站防黑(防XSS攻击、防注入漏洞攻击、防CC攻击、防挂马、防盗链、敏感词过滤、广告帖智能过滤)、IIS管理与调优、流量分析、第三方脚本嵌入(广告、统计代码、内容联盟等)、图片服务器分离。 项目说明 如鹏网项目是已经上线三年的网站,日访问量最高20000人次,网址www.rupeng.com。本系统旧版本基于PHP、J2EE技术,由如鹏网开发者亲手操刀用.net重写新版本。系统分为前台Web界面、后台管理界面、站内搜索、监控客户端四个子系统。 大型互联网站由于访问量非常大,因此不是那些单纯用ASP.Net控件拖拽开发的开发人员能够开发的,也不是闭门造车能够造出来的,必须是在实际项目中经过无数访问者的使用、反馈、修改才能做出来的。搜房网、汽车之家等大型网站中用到的网站静态化、图片服务器分离、高性能缓存、HTML/JS压缩、CDN、CSS Sprite、负载均衡、Memcached、镜像服务器同步等问题不是那些随手写出来的所谓在线商城、电子商务系统所所能够涉及到的。 这个项目完全按照高访问量互联网站进行设计,通过这个项目,学员不仅可以在实战中巩固对前面学习的ASP.Net、ADO.Net、WinForm等知识的掌握,还可以掌握网站防黑、缓存、SEO、静态化、搜索引擎技术、AJAX等大型互联网开发中涉及到的技术。 8、.Net新技术(Windows Phone、ASP.Net MVC)(6天) 项目说明 未来是移动互联网的时代,未来将是Windows Phone、Android、iphone三足鼎立的时代,掌握了移动开发的技能的人是就业市场的抢手货。微软推出的Windows Phone平台是微软在移动互联网时代的一个重量级产品,微软对于WindowsPhone7的推广力度非常大,因此很多公司也开始进行Windows Phone7产品的研发,2011年下半年Windows Phone7开发人员的需求将会出现井喷,为了帮助学员掌握移动3G开发技术,传智播客.Net班加入了Windows Phone开发课程,采用传智播客独创的WP7Simulator教学平台,学员可以做出一个基于云计算架构的LBS系统。点击查看传智播客独创WP7Simulator教学平台。 ASP.Net MVC是微软推出的区别于ASP.Net WebForm的Web开发新技术,由于ASP.Net MVC解决了ASP.Net WebForm的很多缺点,非常适合大型、中型项目的开发,一经推出就受到了.Net开发社区的追捧,很多.Net开发人员的职位要求中都提到了MVC,可见掌握ASP.Net MVC技术必将提升自己就业的砝码。 9、就业指导(2天) 项目说明 总结以往所学知识,讲解《传智播客.Net面试、笔试宝典》,介绍简历、笔试、面试等所需的知识和技巧。

62,041

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

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