我们在做sql查询的时候,有时候需要将查询的列作为表名,去引用,然后再次查询

declare @table_name varchar(20) 
select @table_name=table_name from a where <条件>
exec('select * from '+@a) 此sql其实就是先将sql拼接成字符串,然后再将字符串转成sql指令,如果查询到的结果只有一
列的时候,我们可以这样做,如果
@table_name的值有多个,则无法运用此方法

但是,如果碰到这种情况,我们查询的表名并不只有一列,而是多列,则无法运用此方法
这个时候,我们可以采用union ,通过关联不同的表名,来取到对应表的数据,然后再
将所有数据拼接起来,得到最终的结果

SELECT 
   A.业务号 AS '业务号',
   A.提单号 AS '提单号',
   A.委托方KID AS '委托方KID',
   A.货主KID AS '货主KID',
   CAST(A.计费吨 as decimal(20,3)) AS '计费吨',
   A.收付类型 AS '收付类型',
   convert(varchar(10),A.业务日期,120) AS '业务日期',
   CAST(A.实际金额 as decimal(20,2)) AS '实际金额',
   A.币种 AS '币种'
   FROM (
   SELECT ASN.ORDER_NO AS '业务号', 
   ASN.BL_NO AS '提单号',
   EXT.CORPORATION_ID AS '委托方KID',
   CUS.CORPORATION_ID AS '货主KID',
   CASE WHEN ASN.GROSS_WEIGHT>ASN.VOLUME THEN ASN.GROSS_WEIGHT ELSE ASN.VOLUME END AS '计费吨',
   CASE WHEN F.AR_AP='AR' THEN '应收' ELSE '应付' END AS '收付类型',
   ASN.FINISHED_TIME AS '业务日期',--记账日期
   F.ACTUAL_AMOUNT AS '实际金额',
   F.ORGIANL_CURRENCY AS '币种'
   FROM F_CHARGE F 
   INNER JOIN WMS_ASN ASN 
   ON ASN.KID=F.JOB_ID
   INNER JOIN D_CORPORATION_EXT CUS --货主
   ON CUS.KID=ASN.CUSTOMER_ID 
   INNER JOIN D_CORPORATION_EXT EXT --委托方
   ON EXT.KID=ASN.CONSIGNER
   WHERE F.JOB_TYPE='WMS_ASN'
   UNION ALL
  SELECT CDO.ORDER_NO AS '业务号', 
  CDO.BL_NO AS '提单号',
  EXT.CORPORATION_ID AS '委托方KID',
  CUS.CORPORATION_ID AS '货主KID',
  CASE WHEN CDO.GROSS_WEIGHT>CDO.VOLUME THEN CDO.GROSS_WEIGHT ELSE CDO.VOLUME END AS '计费吨',
  CASE WHEN F.AR_AP='AR' THEN '应收' ELSE '应付' END AS '收付类型',
  CDO.FINISHED_TIME AS '业务日期',--记账日期
  F.ACTUAL_AMOUNT AS '实际金额',
  F.ORGIANL_CURRENCY AS '币种'
  FROM F_CHARGE F
  INNER JOIN WMS_CDO CDO 
  ON CDO.KID=F.JOB_ID
  INNER JOIN D_CORPORATION_EXT CUS --货主
  ON CUS.KID=CDO.CUSTOMER_ID 
  INNER JOIN D_CORPORATION_EXT EXT --委托方
  ON EXT.KID=CDO.CONSIGNER
  WHERE F.JOB_TYPE='WMS_CDO'
  ) AS A
  ORDER BY 
  A.业务号,
  A.提单号,
  A.委托方KID,
  A.货主KID

在此sql中,其实F_CHARGE表中的JOB_TYPE里面存的是表名,JOB_ID里面存的是
表对应的ID,我们需要根据不同的JOB_TYPE,从不同表里面取到不同的数据,这个
时候,我们就可以通过不同的表名,来union不同的语句,最后就不同的查询列拼
接起来得到最终结果。



[BILL WEI]SQL 如何将查询到的列作为表名去查询数据的更多相关文章

  1. sqlite 查询数据库中所有的表名,判断某表是否存在,将某列所有数值去重后获得数量

    1.列出当前db文件中所有的表的表名 SQL语句:SELECT * FROM sqlite_master WHERE type='table'; 结构如下: 注:网上有人说可以带上db文件的名称,如: ...

  2. sql的嵌套查询,把一次查询的结果做为表继续进一步查询;内联视图

    Mysql的嵌套表查询 嵌套SELECT语句也叫子查询,一个 SELECT 语句的查询结果能够作为另一个语句的输入值.子查询可以: 出现在Where子句中, 出现在from子句中,作为一个临时表使用, ...

  3. Sql Server根据表名生成查询的存储过程(查询条件可选)

    static void Main(string[] args) { string 表名 = "water_emstime"; string sql = "exec Get ...

  4. MySQL 子查询(三) 派生表、子查询错误

    From MySQL 5.7 ref:13.2.10.8 Derived Tables 八.派生表 派生表是一个表达式,用于在一个查询的FROM子句的范围内生成表. 例如,在一个SELECT查询的FR ...

  5. SQLSERVER | 查询数据库中所有的表的名字 | 查询数据库中的所有数据库名

    SQLSERVER 1.查询某个数据库中所有的表名:  SELECT Name FROM SysObjects Where XType='U' ORDER BY Name 2.查询数据库中的所有数据库 ...

  6. Mysql查询的一些操作(查表名,查字段名,查当月,查一周,查当天)

    查询数据库中所有表名 select table_name from information_schema.tables where table_schema='tools' and table_typ ...

  7. Mysql 查询出某列字段 被包含于 条件数据中

    我们通常是使用  某条件  是否包含于 某列中   ,简单点 就是:select * from 表名 where  字段名 like '%条件数据%'; 现在说下   某列 被包含于 条件数据中 接下 ...

  8. 【SQL必知必会笔记(1)】数据库基础、SQL、MySQL8.0.16下数据库、表的创建及数据插入

    文章目录 1.数据库基础 1.1 数据库(database) 1.2 表(table) 1.3 列和数据类型 1.4 行 1.5 主键 2.什么是SQL 3.创建后续练习所需数据库.表(MySQL8. ...

  9. [BILL WEI]SQL 存储过程学习

    --查看数据库exec sp_databases ;--查看表exec sp_tables ;--查看列exec sp_columns WMS_ASN;--查看索引exec sp_helpindex ...

随机推荐

  1. 解决VS2008打开假死或者打开设计模式假死的问题

    我昨天刚装完OFFICE 2010一直也没重启,vs2008是可以使用的.今早来到办公室,打开工程发现开了半天VS2008一般空白,查看应用程序显示正在运行,再查看进程发现里面多一个setup.exe ...

  2. 《C和指针》读书笔记——第二章 基本概念

    1.编译过程: source code→Compiler→Object code→Linker←Lib ↓ Exe 2.经过初始化的静态变量(static)在程序执行前能获得他们的值. 3.绝大多数环 ...

  3. twisted internet.reactor部分 源码分析

    twisted.internet.reactor 是进行所有twisted事件循环的地方. reactor在1个python进程中只能有一个. 在windows下用的是select.linux下epo ...

  4. 在VS中手工创建一个最简单的WPF程序

    如果不用VS的WPF项目模板,如何手工创建一个WPF程序呢?我们来模仿WPF模板,创建一个最简单的WPF程序. 第一步:文件——新建——项目——空项目,创建一个空项目. 第二步:添加引用,Presen ...

  5. 深入理解Oracle的imp/exp 和各版本之间的规则

    Oracle数据中IMP/EXP工具可用于对数据进行迁移.IMP命令用于把Dmp文件从本地导入到远程数据库服务器,而EXP命令则是把数据从远程数据库服务器导出到本地的Dmp文件.其功能相当于Oracl ...

  6. poj 2001 Shortest Prefixes trie入门

    Shortest Prefixes 题意:输入不超过1000个字符串,每个字符串为小写字母,长度不超过20:之后输出每个字符串可以简写的最短前缀串: Sample Input carbohydrate ...

  7. 【Http】Http权威指南

    God Is Coder 2012-10-17 22:25 阅读:77 评论:0   <http权威指南>阅读笔记(十二) God Is Coder 2012-10-17 22:04 阅读 ...

  8. 【WEB-INF】WEB-INF是Java的WEB应用的安全目录

    WEB-INF下的东西是禁止直接访问的.如果这个页面是你的,要想让人访问最好不要放在这个目录下.如果一定放在那里.你可以使用:request.getRequestDispatcher("/W ...

  9. vi 在行首尾添加字符串

    在行首尾添加字符串     用下列命令在文本每行的行首添加字符串“NewString”,请注意空格的存在.      :g/^/s//NewString/g     :%s/^/NewString/g ...

  10. cocos2dx3.4 分割plist图片

    如果想要修改一个plist文件新打包成plist,而此刻原来的小图都找不到了,那只能把plist分解了,代码如下: void UiManage::DecodePlist(string imgPath, ...