CSDN首页 空间 新闻 论坛 Blog 下载 读书 网摘 搜索 .NET Java 视频 接项目 求职 在线学习 买书 程序员 通知
不看会后悔的Windows XP之经验谈 简单快捷DIY实用家庭影院
CSDN社区
搜索 收藏 打印 关闭
CSDN社区 >  MS-SQL Server >  疑难问题

这个的SQL语句如何写?!? 关于两个表间的数据.

楼主kenpa(大海无量)2003-12-04 00:58:23 在 MS-SQL Server / 疑难问题 提问

表一:定价表        
   
  字段有       公司名称     ,价格   ,   产品  
                      大发公司       20         显示器  
                      全部               30         显示器  
                      全部               100       硬盘  
   
   
  表二:报价表  
   
  字段有     公司名称   ,   价格   ,产品  
                   
   
   
  问题是:     如果定价表中有   公司名称='大发公司'的   所有产品   的定价,则复制一份到  
  报价表,   如果没有,如果某种产品没有大发公司报价的,   就把公司名称='全部'的报价复制过来.比如说上面,   就是要把第一条跟第三记记录复制到   报价表  
   
   
   
   
   
   
   
   
  问题点数:60、回复次数:5Top

1 楼kenpa(大海无量)回复于 2003-12-04 01:48:34 得分 0

 
  问我同事搞定了  
   
   
  分两步  
   
  select   '大发公司',   价格,   产品   from   定价表  
  where   公司名称='大发公司'   and   产品   not   in  
  (  
  select   产品   from   报价表   where   公司名称='大发公司'  
  )  
     
   
   
  select   '大发公司',   价格,   产品   from   定价表  
  where   公司名称='全部'   and   产品   not   in  
  (  
  select   产品   from   报价表   where   公司名称='大发公司'  
  )    
  Top

2 楼pengdali()回复于 2003-12-04 08:37:51 得分 0

insert   报价表   (公司名称,价格,产品)    
  select   公司名称,价格,产品   from   定价表   where   公司名称='大发公司'  
  union   all  
  select   公司名称,价格,产品   from   定价表   where   产品   not   in   (select   产品   from   定价表   where   公司名称='大发公司')  
  Top

3 楼pengdali()回复于 2003-12-04 08:39:54 得分 50

insert   报价表   (公司名称,价格,产品)    
  select   公司名称,价格,产品   from   定价表   where   公司名称='大发公司'  
  union   all  
  select   公司名称,价格,产品   from   定价表   where   公司名称='全部'   and   产品   not   in   (select   产品   from   定价表   where   公司名称='大发公司')  
   
  或:  
   
  insert   报价表   (公司名称,价格,产品)    
  select   公司名称,价格,产品   from   定价表   where   公司名称='大发公司'   or   (公司名称='全部'   and   产品   not   in   (select   产品   from   定价表   where   公司名称='大发公司'))Top

4 楼victorycyz(--)回复于 2003-12-04 08:46:47 得分 0

select   a.*    
  into   报价表    
  from   定价表   a   join    
                  (select   min(公司名称)   as   公司,产品    
                    from   定价表    
                    group   by   产品    
                    where   产品   in   ('大发公司','全部')  
                  )   T     on   a.产品=T.产品   and   a.公司名称=T.公司Top

5 楼victorycyz(--)回复于 2003-12-04 08:48:39 得分 10

上面错了,报价表已有了:  
   
  insert   into   报价表  
  select   a.*    
  from   定价表   a   join    
                  (select   min(公司名称)   as   公司,产品    
                    from   定价表    
                    group   by   产品    
                    where   产品   in   ('大发公司','全部')  
                  )   T     on   a.产品=T.产品   and   a.公司名称=T.公司  
  Top

相关问题

  • ////请问:ACCESS数据库清空表数据的SQL语句////
  • 用sql语句查询数据表中有哪些字段是什么语句?
  • 如何用SQL语句复制表和表中的数据???急!!!
  • 如何实现sql语句复制数据表结构的?
  • 通过SQL语句查看数据库中所有表名
  • 执行sql语句删除表的数据的操作问题
  • 如何用SQL语句拆分数据表
  • 怎么用sql语句随机取一个表的数据?
  • 请教如何得到数据表结构的sql语句。
  • 用SQL语句转换表里的数据问题

关键词

  • 名称
  • 报价
  • 表
  • 产品
  • 价格
  • 公司
  • 复制
  • from定价表where
  • select

得分解答快速导航

  • 帖主:kenpa
  • pengdali
  • victorycyz

相关链接

  • SQL Server类图书

广告也精彩

反馈

请通过下述方式给我们反馈
反馈
提问
网站简介|广告服务|VIP资费标准|银行汇款帐号|网站地图|帮助|联系方式|诚聘英才|English|问题报告
世纪乐知(北京)网络技术有限公司 版权所有, 京 ICP 证 020026 号
北京创新乐知广告有限公司 提供技术支持
Copyright © 2000-2007, CSDN.NET, All Rights Reserved
GongshangLogo