SELECT * FROM (select aa.*,bb.mentalvisitid,
case when bb.BCSFXS='' then '门诊' when bb.BCSFXS='' then '家庭访视' else '电话' end as BCSFXS ,bb.visitdate,
case when bb.Hospitalstatus='' then '目前正在住院' when bb.Hospitalstatus='' then '曾住院,现未住院' else '未住院' end as Hospitalstatus,
case when bb.visittype='' then '不稳定' when bb.visittype='' then '基本稳定' else '稳定' end as visittype ,
case when bb.Followmedicine='' then '按医嘱规律用药' when bb.Followmedicine='' then '间断用药' when bb.Followmedicine='' then '不用药' else '医嘱无需用药' end as Followmedicine,
case when bb.Treatment='' then '痊愈' when bb.Treatment='' then '好转' when bb.Treatment='' then '无变化' when bb.Treatment='' then '加重' else '此项不适用' end as Treatment,
case when bb.Labcheck ='' then '有' else '无' end as Labcheck, bb.labcheckother, (CASE WHEN bb.SYMPTOMS like '%1%' then '幻觉 ' end ||
CASE WHEN bb.SYMPTOMS like '%2%' then '交流困难 ' end ||
CASE WHEN bb.SYMPTOMS like '%3%' then '猜疑 ' end ||
CASE WHEN bb.SYMPTOMS like '%4%' then '喜怒无常 ' end ||
CASE WHEN bb.SYMPTOMS like '%5%' then '行为怪异 ' end ||
CASE WHEN bb.SYMPTOMS like '%6%' then '兴奋话多 ' end ||
CASE WHEN bb.SYMPTOMS like '%7%' then '伤人毁物 ' end ||
CASE WHEN bb.SYMPTOMS like '%8%' then '悲观厌世 ' end ||
CASE WHEN bb.SYMPTOMS like '%9%' then '无故外走 ' end ||
CASE WHEN bb.SYMPTOMS like '%10%' then '自语自笑 ' end ||
CASE WHEN bb.SYMPTOMS like '%11%' then '孤僻懒散 ' end ||
CASE WHEN bb.SYMPTOMS like '%12%' then '其他 ' end
) as SYMPTOMS,
(CASE WHEN bb.RECOVERYMANNER like '%1%' then '生活劳动能力 ' end ||
CASE WHEN bb.RECOVERYMANNER like '%2%' then '职业训练 ' end ||
CASE WHEN bb.RECOVERYMANNER like '%3%' then '学习能力 ' end ||
CASE WHEN bb.RECOVERYMANNER like '%4%' then '社会交往 ' end ||
CASE WHEN bb.RECOVERYMANNER like '%5%' then '其他 ' end
) as RECOVERYMANNER, (select wm_concat(to_char(medname) || '(' || '每日' || to_char(usage) || '次 , ' || to_char(amount) || ')' )
from MB_MentalVisit_Medicine
where ISSTATE = ''
and Mentalvisitid = bb.mentalvisitid) AS MEDICINE, case when bb.DANGERSTATUS='' then '0级' when bb.DANGERSTATUS='' then '1级' when bb.DANGERSTATUS='' then '2级' when bb.DANGERSTATUS='' then '3级' when bb.DANGERSTATUS='' then '4级' when bb.DANGERSTATUS='' then '5级' end as DANGERSTATUS,
case when bb.SELFKNOW='' then '自知力完全' when bb.SELFKNOW='' then '自知力不全' when bb.SELFKNOW='' then '自知力缺失' end as SELFKNOW,
case when bb.SLEEP='' then '良好' when bb.SLEEP='' then '一般' when bb.SLEEP='' then '较差' end as SLEEP,
case when bb.EATING='' then '良好' when bb.EATING='' then '一般' when bb.EATING='' then '较差' end as EATING,
case when bb.PERSONALLIFE='' then '良好' when bb.PERSONALLIFE='' then '一般' when bb.PERSONALLIFE='' then '较差' end as PERSONALLIFE,
case when bb.FAMILY='' then '良好' when bb.FAMILY='' then '一般' when bb.FAMILY='' then '较差' end as FAMILY,
case when bb.PRODUCTWROK='' then '良好' when bb.PRODUCTWROK='' then '一般' when bb.PRODUCTWROK='' then '较差' end as PRODUCTWROK,
case when bb.STUDY='' then '良好' when bb.STUDY='' then '一般' when bb.STUDY='' then '较差' end as STUDY,
case when bb.SOCIAL='' then '良好' when bb.SOCIAL='' then '一般' when bb.SOCIAL='' then '较差' end as SOCIAL,
bb.VISITDOCTOR,
case when (select Count(*) from MB_Autograph where Sfid=bb.mentalvisitid and Sf_type ='kf_mentalvisit')=1 then '电子签名' else '' end as DZQM,
bb.HZJSQM,
ROW_NUMBER() OVER(PARTITION BY aa.personid ORDER BY bb.Mentalvisitid DESC) RNO from (SELECT PERSONID,
TOWNNAME,
PERSONCODE,
PNAME,
PHONENO,
BIRTHDAY,
RESIDENCEADDRESS,
CREATEDATE,
GENDERCODE,
GENDERNAME,
DISEASE1,
DISDATE1,
DISEASE2,
DISDATE2,
DISEASE3,
DISDATE3,
DISEASE4,
DISDATE4,
DISEASE5,
DISDATE5,
DISEASE6,
DISDATE6,
IDCARDNO,VILLAGENAME,relationname,
(SELECT COUNT(A.MENTALVISITID)
FROM KF_MENTALVISIT A
WHERE A.PERSONID = P.PERSONID
AND A.ISDELETED = '' and Visitdate >= to_date('2015-05-14','yyyy-MM-dd') and Visitdate <= to_date('2018-07-24','yyyy-MM-dd')) AS VISITEDTIMES,
(SELECT B.RELATION
FROM KF_MENTAL B
WHERE B.ISDELETED = ''
AND B.PERSONID = P.PERSONID
AND ROWNUM <= 1) AS RELATION,
(SELECT B.LOCKSITUATION
FROM KF_MENTAL B
WHERE B.ISDELETED = ''
AND B.PERSONID = P.PERSONID
AND ROWNUM <= 1) AS LOCKSITUATION,
(SELECT B.RECENTDIAGNOSE
FROM KF_MENTAL B
WHERE B.ISDELETED = ''
AND B.PERSONID = P.PERSONID
AND ROWNUM <= 1) AS RECENTDIAGNOSE,
(SELECT GUARDIAN
FROM KF_MENTAL B
WHERE B.ISDELETED = ''
AND B.PERSONID = P.PERSONID
AND ROWNUM <= 1) AS GUARDIAN,
(SELECT FIRSTTIME
FROM KF_MENTAL B
WHERE B.ISDELETED = ''
AND B.PERSONID = P.PERSONID
AND ROWNUM <= 1) AS FIRSTTIME,ROW_NUMBER() OVER(ORDER BY PERSONCODE DESC) AS RN
FROM DAGL_PERSON P WHERE p.isdeleted = ''
and p.status = '正常'
and p.diseasecode like '%,8,%' and ( p.villagecode like '370783%' ) and ( p.villagecode like '370783112%' ) and (select count(t.MENTALVISITID) as visitedTimes
from KF_MENTALVISIT t
where t.isdeleted = '' and t.personid = p.personid and Visitdate >= to_date('2015-05-14','yyyy-MM-dd') and Visitdate <= to_date('2018-07-24','yyyy-MM-dd')) >= 1 and exists(select 1 from kf_mental where kf_mental.personid=p.personid) ) aa left join kf_mentalvisit bb ON aa.personid = bb.personid)C
where 1=1 and Visitdate >= to_date('2015-05-14','yyyy-MM-dd') and Visitdate <= to_date('2017-07-24','yyyy-MM-dd')

解析:

1.Case When Then end

 添加的 if else的逻辑

2. wm_concat()   , wm_concat(to_char())

  多条记录合并成一条,类似于for

3.  ||   拼接字符串用

  类似于操作符了

4. () 可以连表查字段

  类似于函数执行一部分操作

5.PARTITION BY ... ORDER BY ... DESC

  多表合并时使用的操作

6.where 条件中  exists()

7.left join  on  注意小括号的使用


sql 应用记录的更多相关文章

  1. SQL重复记录处理(查找,过滤,删除)

    SQL重复记录处理(查找,过滤,删除)     ID int    Title nvarchar(50)    AddDate datetime    数据  www.2cto.com     ID ...

  2. Yii2如何添加sql日志记录的配置信息

    在使用Yii2框架的时候,常常会出现没有sql日志记录的问题.在代码里一句一句的打印sql语句也不现实.所以就要用文件记录起来. 在 config/web.php 里面的 log配置中增加如下配置 [ ...

  3. EF Core3.0+ 通过拦截器实现读写分离与SQL日志记录

    前言 本文主要是讲解EF Core3.0+ 通过拦截器实现读写分离与SQL日志记录 注意拦截器只有EF Core3.0+ 支持,2.1请考虑上下文工厂的形式实现. 说点题外话.. 一晃又大半年没更新技 ...

  4. 如何在MySql中记录SQL日志记录

    My SQL可以用下面方法跟踪sql 语句,以下方法以Windows平台为例,linux雷同:   1  配置my.ini文件(在安装目录,linux下文件名为my.cnf     查找到[mysql ...

  5. SQL学习记录

    一些最重要的 SQL 命令 SELECT - 从数据库中提取数据 UPDATE - 更新数据库中的数据 DELETE - 从数据库中删除数据 INSERT INTO - 向数据库中插入新数据 CREA ...

  6. phalcon: plugin 结合Manager事件管理、dispatcher调度控制器 监听sql日志记录或其他拦截出来

    可能用到的类 phalcon\mvc\use\plugin Phalcon\Mvc\Dispatcher as MvcDispatcher Phalcon\Events\Manager as Even ...

  7. SQL查询记录添加序号(HANA)

    语法:ROW_NUMBER() OVER(PARTITION BY COLUMN ORDER BY COLUMN) row_number() OVER() 从1开始,为每一条分组记录返回一个数字,这里 ...

  8. SQL检索记录

    <<第一章检索记录>>:关于表使用SELECT语句和特殊字符"*": *:SELECT * from emp; 1:分别列出每一行:SELECT empno ...

  9. SQL 问题记录

    今天在处理SQL的时候遇到几个问题: 1.如果指定了 SELECT DISTINCT,那么 ORDER BY 子句中的项就必须出现在选择列表中 select distinct id from 收费站 ...

  10. sql知识点记录

    order by就是排序. group by就是分组. WHERE语句在GROUP BY语句之前:SQL会在分组之前计算WHERE语句.    HAVING语句在GROUP BY语句之后:SQL会在分 ...

随机推荐

  1. " ModuleNotFoundError: No module named 'tkinter' "的解决方法

    踩坑场景 在使用pillow这个包处理图片的时候,运行程序,报错ModuleNotFoundError: No module named 'tkinter',遇到ModuleNotFoundError ...

  2. 深入浅出Mybatis系列九-强大的动态SQL

    注:本文转载自南轲梦 注:博主 Chloneda:个人博客 | 博客园 | Github | Gitee | 知乎 上篇文章<深入浅出Mybatis系列(八)---mapper映射文件配置之se ...

  3. SEO中10个常用的查询指令

    用好搜索引擎一些特别指令,是干SEO这行的一个根本功.初步收拾了10个功能,独自使用是最基础的才能,假如综合应用,你会发现搜索的奇妙无限. 1. site: 某个特定网站收录情况 site:www.c ...

  4. 关于Comparable和Comparator那些事

    在实际项目开发过程中,我们经常需要对某个对象或者某个集合中的元素进行排序,常用的两种方式是实现某个接口.常见的可以实现比较功能的接口有Comparable接口和 Comparator接口,那么这两个又 ...

  5. [Err] 1248 - Every derived table must have its own alias

    问题描述 [Err] 1248 - Every derived table must have its own alias 问题原因 这句话的意思是说每个派生出来的表都必须有一个自己的别名 我的Mys ...

  6. Codeforces 1304D. Shortest and Longest LIS 代码(构造 贪心)

    https://codeforces.com/contest/1304/problem/D #include<bits/stdc++.h> using namespace std; voi ...

  7. SocketAsyncEvent方式的Server

    1.AsyncUserToken public class AsyncUserToken { /// <summary> /// 客户端IP地址 /// </summary> ...

  8. canvas转盘转动?

    怎么实现类似转盘转动的效果? 现在这种实现思路是,canvas每次draw()并不是让图形在旋转,而是让每一份的颜色改变到达好像是转动的效果, 但是现在有一个问题,一开始渲染的颜色数量于份数是相同的, ...

  9. [hive]case 语句中字符串匹配

    当使用case when时,有时会需要对某个字段做子串匹配.如果是在where条件中,我们会直接使用 like '%xx%'来匹配,但case when语句不行 这时需要使用instr函数 examp ...

  10. C++-POJ3213-PM3-[矩阵乘法]

    已知矩阵乘法是n^3的,必然超时 故可以在需要验证的等式AB=C两边同时左乘D 一个1xN的任意的不含0矩阵 设E=DA,F=EB,G=DC,则此时只需验证F=G 当匹配到非法列J时,跳出n^2寻找行 ...