SELECT distinct
      u.Name as UserName,
      a.OrderId,
      (
      select  d.SignCity from T_OperaterInfo o left join T_DepartmentInfo d on o.DepId=d.DepId where o.OptId=a.CreateUserId
      ) jinjianchengshi,
      o.Name as lurukefu,
      p.ProductName,
      VerifyName = v.VerifyName ,
      DepName=
      (
      select  D6.DepName from  T_OperaterInfo O5
      left join  T_DepartmentInfo D5 on D5.DepId = O5.DepId
      left join  T_DepartmentInfo D6 on D6.DepId = D5.ParentDepId
      where  a.FirstVerifyOptId = O5.OptId
      ) ,
      a.NetAmount,
      a.Amount,
      a.Term,
      a.RepayPerMonth,
      (select count(1) from T_VerifySituation v1 where v1.VerifyStatus=1005 and v1.OrderId=a.OrderId) tuihuicishu,
      vst3.RefuseWayName as  jujueyuanyin,
      vst10.VerifyDate   as  lixiangshijian,
      'jinjianshijian' =
      case
      when  ( CONVERT(varchar(100), vs2.VerifyDate, 20)) is not null then ( CONVERT(varchar(100), vs2.VerifyDate, 20))
      else
      CONVERT(varchar(100),  vst4.VerifyDate , 20)
      end,
      vst5.VerifyDate  as  zongpingshijian,
      CONVERT(varchar(100), a.ContractStartDate, 20) jihuaqianyueshijian ,
      CONVERT(varchar(100), a.ContractEndDate, 20) hetongjieshushijian,
      (select O1.Name from T_OperaterInfo O1 where O1.OptId=  a.FirstVerifyOptId ) chushen,
      (select O2.Name from T_OperaterInfo O2 where O2.OptId=  a.LastVerifyOptId ) zhongshen,
      (select O3.Name from T_OperaterInfo O3 where O3.OptId=  a.TotalReviewOptId ) zongping,
      (select O4.Name from T_OperaterInfo O4 where O4.OptId=  a.ReconsiderOptId ) fuyi,
      ''''+(  select cast(u.IDCard as varchar(25)))  as  IDCard,
      vst6.AuditOpinion as  chushenyijian,
      vst7.AuditOpinion as   zhongshenyijian,
      vst8.AuditOpinion as   zongpingyijian,
      vst9.AuditOpinion as  fuyiyijian,
      shifougenggaichanpin = case when a.IsAccordanceProduct=1 then '是' else '否' end ,
      'ChangeProductName'=
      case
      when  (a.ChangeProductName is not null and a.ChangeProductName != '')   then substring(a.ChangeProductName,0,charindex(',', ChangeProductName))
      end,
      shifoulianmingjiekuan =case when a.IsCoborrowLoan = 1 then '是' else '否' end,
      'CoborrowName'=
      case
      when  (a.CoborrowName is not null and a.CoborrowName !=  '')   then substring(a.CoborrowName,0,charindex(',', CoborrowName))
      end
      FROM  T_LoanProductOrder as a
      inner join T_UserInfo as u on a.UserId=u.UserId
      inner join T_VerfyStatus as v on a.VerifyStatus=v.VerifyId
      inner join T_Product as p on a.ProductTypeId=p.ProductId
      left join T_OperaterInfo as o on o.OptId=a.CreateUserId
      left join T_DepartmentInfo as d on o.DepId=d.DepId
      left join T_UserWorkInfo as w on u.UserId=w.UserId
      left join (select     OrderId, VerifyDate = max (VerifyDate)  ,flag=count(*) from T_VerifySituation where  VerifyStatus=3023 group by OrderId  ) vs2 on a.OrderId=vs2.OrderId
      left join (select    OrderId, RefuseWayName ,VerifyDate = max (VerifyDate) ,flag=count(*) from T_VerifySituation where  VerifyStatus in (1015,1016) group by OrderId ,RefuseWayName) vst3 on a.OrderId=vst3.OrderId
      left join (select    OrderId ,VerifyDate = max (VerifyDate)  ,flag=count(*) from T_VerifySituation where  VerifyStatus in (1002) group by OrderId ) vst4 on a.OrderId=vst4.OrderId
      left join (select    OrderId ,VerifyDate = max (VerifyDate) ,flag=count(*)  from T_VerifySituation where  VerifyStatus in (1008 ,1015 )   group by OrderId ) vst5 on a.OrderId=vst5.OrderId
      left join (select OrderId ,VerifyDate,AuditOpinion from (
select ROW_NUMBER() over(partition by OrderId order by VerifyDate desc) ROWNO,OrderId ,VerifyDate = max (VerifyDate),AuditOpinion 
from T_VerifySituation where  VerifyStatus in (1004,1005,3013,3016,1028 )  group by OrderId,VerifyDate,AuditOpinion
) as t   where ROWNO=1 ) vst6 on a.OrderId=vst6.OrderId
      left join (
 select OrderId ,VerifyDate,AuditOpinion from (
select ROW_NUMBER() over(partition by OrderId order by VerifyDate desc) ROWNO,OrderId ,VerifyDate = max (VerifyDate),AuditOpinion 
from T_VerifySituation where  VerifyStatus in (1006,1007,3018,3025,1029 )  group by OrderId,VerifyDate,AuditOpinion
) as t   where ROWNO=1 ) vst7 on a.OrderId=vst7.OrderId
      left join (
 select OrderId ,VerifyDate,AuditOpinion from (
select ROW_NUMBER() over(partition by OrderId order by VerifyDate desc) ROWNO,OrderId ,VerifyDate = max (VerifyDate),AuditOpinion 
from T_VerifySituation where  VerifyStatus in (1008, 1009 ,1015)  group by OrderId,VerifyDate,AuditOpinion
) as t   where ROWNO=1
 ) vst8 on a.OrderId=vst8.OrderId
      left join (
 select OrderId ,VerifyDate,AuditOpinion from (
select ROW_NUMBER() over(partition by OrderId order by VerifyDate desc) ROWNO,OrderId ,VerifyDate = max (VerifyDate),AuditOpinion 
from T_VerifySituation where  VerifyStatus in (1010,1011)  group by OrderId,VerifyDate,AuditOpinion
) as t  where ROWNO=1 ) vst9 on a.OrderId=vst9.OrderId
      left join (select    OrderId ,VerifyDate = min (VerifyDate),AuditOpinion ,flag=count(*)  from T_VerifySituation where  VerifyStatus in (1002) group by OrderId ,AuditOpinion ) vst10 on a.OrderId=vst10.OrderId
      where 1=1
  and a.ProductTypeId !=30013 
  and a.OrderId=11376

复杂的sql 一对多查询的更多相关文章

  1. sql 一对多查询

    1. 一对多查询 查询departmentinfo字典下所有部门的人员数量 select * from departmentinfo a left join (select count(*) User ...

  2. sql 一对多查询最近一条

    感谢 http://bbs.csdn.net/topics/391048578?page=1 create table A ( [Id] [uniqueidentifier] NOT NULL, ) ...

  3. [译]LINT TO SQL 介绍(数据库查询) - Part.3

    出处:Linq To Sql (Part.3 – Querying our database) 术语表 Built-in:内置的 Clause:子句 Debugger:调试器 Object Relat ...

  4. mybatis0204 一对多查询

    查询所有订单信息及订单下的订单明细信息. sql语句 主查询表:订单表 关联查询表:订单明细 SELECT orders.*, user.username, user.sex , orderdetai ...

  5. JAVAEE——Mybatis第二天:输入和输出映射、动态sql、关联查询、Mybatis整合spring、Mybatis逆向工程

    1. 学习计划 1.输入映射和输出映射 a) 输入参数映射 b) 返回值映射 2.动态sql a) If标签 b) Where标签 c) Sql片段 d) Foreach标签 3.关联查询 a) 一对 ...

  6. mybatis的一对一,一对多查询,延迟加载,缓存介绍

    一对一查询 需求 查询订单信息关联查询用户信息 sql语句 /*通过orders关联查询用户使用user_id一个外键,只能关联查询出一条用户记录就可以使用内连接*/ SELECT orders.*, ...

  7. mybatis第二天——动态SQL与关联查询

    大纲摘要: 1.输入映射和输出映射 a) 输入参数映射 b) 返回值映射 2.动态sql a) If b) Where c) Foreach d) Sql片段 3.关联查询 a) 一对一关联 b) 一 ...

  8. mybatis由浅入深day02_3一对多查询

    3 一对多查询 3.1 需求(查询订单及订单明细的信息) 查询订单及订单明细的信息. 3.2 sql语句 确定主查询表:订单表 确定关联查询表:订单明细表 在一对一查询基础上添加订单明细表关联即可. ...

  9. hibernate一对多查询

    一对多查询 1,同时添加老师和学生案例 在进行具有关联关系的对象同时添加时 首先绑定对像间的关系 ---将多方关联一方 ---将一方关联多方 然后全部添加 备注: 1,保存老师对象时, 由于设置了学生 ...

随机推荐

  1. BIP_开发案例01_BI Publisher报表手工提交和控制(案例)

    2014-12-27 Created By BaoXinjian

  2. silverlight 报 System.NullReferenceException 未将对象引用设置到对象的实例。

    在 Microsoft.Windows.Design.Platform.SilverlightMetadataContext.SilverlightXamlExtensionImplementatio ...

  3. SDcard进行文件的读取

    平时我们需要在手机上面存储想音频,视频等等的大文件,以前学过使用File进行存储(使用File操作进行存储):由于考虑到手机本身的存储空间小,这时候我们需要把文件存储在SDcard中,今天自己也学习了 ...

  4. Mac 10.10下安装MySQL5.6.21提示安装失败

    只要要在安装的第三步在自定里不要选Startup item就可以了

  5. laravel项目return back()->withErrors($validator)或return back()->with('errors','原密码错误!')在前台原密码错误的情况下不能正确显示错误信息,变成报错!

    被折磨的答案是 php artisan --version看一下版本,如果是5.2.26以上的,在路由处删除web中间件分组,还有问题再反馈

  6. mysql 按年度、季度、月度、周、日SQL统计查询

    创建Table CREATE TABLE `test` ( `cdate` datetime DEFAULT NULL, `id` ) DEFAULT NULL, `name` ) DEFAULT N ...

  7. [ActionScript 3.0] AS3 3D双圆环贴图

    package { import flash.display.Bitmap; import flash.display.BitmapData; import flash.display.MovieCl ...

  8. java:jdk环境变量配置+tomcat环境变量配置

    一:JDK1.先安装jdk  查看jdk版本:   DOC下输入java -version2.配置环境变量(添加系统变量)  JAVA_HOME      D:\study\jdk-6\jdk-6(j ...

  9. MVC 4 与WebForm 混合应用 WebApi 发布常见问题

    1.所有应用的MVC相关程序集编译时要选择复制到本地,需要用到的程序如下图 2.IIS设置: 因为 IIS 7/8 采用了更安全的 web.config 管理机制,默认情况下会锁住配置项不允许更改.运 ...

  10. 第七届蓝桥杯C++B组省赛

    1.煤球数目 2.生日蜡烛 3.凑算式 4.快速排序 5.抽签 6.方格填数 7.剪邮票 8.四平方和 9.交换瓶子 10.最大比例 今天是周三了,周天刚考完,这次做的还是不好(上次是全省最后一名). ...