1、使用mysql的union all可以同时查询出所有自己想要查询数据表的数据量。

 select 'user' as tablename, count(*) from user
union all select 'teacher' as tablename, count(*) from teacher
union all select 'person' as tablename, count(*) from person
union all select 'student' as tablename, count(*) from student
order by tablename

2、使用mysql的union all可以同时查询出所有自己想要查询数据表的数据量。添加上限制条件进行查询。

 select 'user' as tablename, count(*) from user                                         where update_time>'2018-10-09'
union all select 'teacher' as tablename, count(*) from teacher where update_time>'2018-10-09'
union all select 'person' as tablename, count(*) from person where update_time>'2018-10-09'
union all select 'student' as tablename, count(*) from student where update_time>'2018-10-09'
order by tablename

3、使用Postgresql或者Greenplum的union all可以同时查询出所有自己想要查询数据表的数据量。添加上限制条件进行查询。

 select 'user' as tablename, count(*) from user                                          where update_time>to_date('2018-10-09 01', 'yyyy-mm-dd hh24')
union all select 'teacher' as tablename, count(*) from teacher where update_time>to_date('2018-10-09 01', 'yyyy-mm-dd hh24')
union all select 'person' as tablename, count(*) from person where update_time>to_date('2018-10-09 01', 'yyyy-mm-dd hh24')
union all select 'student' as tablename, count(*) from student where update_time>to_date('2018-10-09 01', 'yyyy-mm-dd hh24')
order by tablename

4、在Mysql数据库中,如果某个字段是换行的,如何去掉换行的字段,然后正常查询出来。
    注意:char(10)换行键、char(13)回车键。
    4.1、查询出多个数据表某条记录可能含有换行符的记录。
        CONCAT()函数用于将多个字符串连接成一个字符串。

 select * from user where name like CONCAT("%",char(),"%")
union all select * from teacher where name like CONCAT("%",char(),"%")
union all select * from person where name like CONCAT("%",char(),"%")
union all select * from student where name like CONCAT("%",char(),"%");

4.1、然后将换行和回车进行替换,将换行和回车换成''。这样做就将回车和换行替换完成。
        replace(object,search,replace),把object中出现search的全部替换为replace。

 select REPLACE(REPLACE(name, char(), ''), char(), '') as name from user where name like CONCAT("%",char(),"%")
union all select REPLACE(REPLACE(name, char(), ''), char(), '') as name from student where name like CONCAT("%",char(),"%")
union all select REPLACE(REPLACE(name, char(), ''), char(), '') as name from person where name like CONCAT("%",char(),"%")
union all select REPLACE(REPLACE(name, char(), ''), char(), '') as name from student where name like CONCAT("%",char(),"%");

4.3、可以将回车符和换行符转换为特殊的字符。
        -- 将char(10)换行键,char(13)回车键换成@#r;和@#n;

  select REPLACE(REPLACE(name, char(), '@#r;'), char(), '@#n;') as name from user where name like CONCAT("%",char(),"%")

如果需要有需要,可以将特殊的字符再转换为回车符和换行符。
        -- 将@#r;和@#换成nchar(10)换行键,char(13)回车键;

  select REPLACE(REPLACE(name, '@#r;', char()), '@#n;', char()) as name from user where name like CONCAT("%",char(),"%")

5、    查询出最大时间,可以根据这个来进行批次插入数据和批次导出数据。
    5.1、Postgresql和Greenplum的用法:
        COALESCE()的用法,如果第一个参数不为null,咋返回第一个参数,否则返回第二个参数。

 select '数据表名称' as table_name,  as part, COALESCE(max(update_time), now()) as next_time from schema.数据表名称

5.2、Mysql的用法:
        ifnull()的用法,如果第一个参数不为null,咋返回第一个参数,否则返回第二个参数。

 select 'user' as table_name,ifnull(max(update_time),now()) as update_time from user;

6、MYSQL或者Postgresql和Greenplum的Case...When的用法基本相同。
    6.1、Case expr when v1 then r1 when v2 then r2 else rn end。该函数表示,如果expr值等于某个vn,则返回对应位置then后面的结果,如果所有值都不相等,则返回else后面的rn。

  select case  when  then 'one' when  then 'two' else 'more' end;

6.2、case when v1 then r1 when v2 then r2 else rn end。该函数表示,某个vn为true的时候,则返回对应位置then后面的结果,如果所有值都不相等,则返回else后面的rn。

  select case when  <  then 'true' when  >  then 'false' else 'more' end;

7、查询最大批次号,如果不存在根据规则生成一个批次号。
    Postgresql和Greenplum使用to_number()函数来转换成整数、to_char()将数字转为字符串。mysql无此函数。
    完整的例子如下所示:

 select to_char(to_number(COALESCE(max("Cd_batch"), to_char(now(), 'yyyyMMdd')||''), '') + , '') from schema.数据表名称 where "TableName"='数据表名称' and "Cd_source"='数据来源'

步骤一:获取最大的批次号:

 select max("Cd_batch") from schema.数据表名称 where "TableName"='数据表名称' and "Cd_source"='数据来源'

步骤二:判断如果最大批次号如果为null,根据规则生成一个批次号。

 select COALESCE(max("Cd_batch"), to_char(now(), 'yyyyMMdd')||'') from schema.数据表名称 where "TableName"='数据表名称' and "Cd_source"='数据来源'

步骤三:将生成的字符串转换为数值类型numeric的,长度为第二个参数的长度,并且批次号加1。这样下发的数据的批次号就是叠加后的批次号。

  select to_number(COALESCE(max("Cd_batch"), to_char(now(), 'yyyyMMdd')||''), '') +  from schema.数据表名称 where "TableName"='数据表名称' and "Cd_source"='数据来源'

步骤四:将生成的数值numeric类型转换为字符串类型的。

 select to_char(to_number(COALESCE(max("Cd_batch"), to_char(now(), 'yyyyMMdd')||''), '') + , '') from schema.数据表名称 where "TableName"='数据表名称' and "Cd_source"='数据来源'

待续......

常用Mysql或者PostGresql或者Greenplum的语句总结。的更多相关文章

  1. mysql迁移mpp数据库Greenplum

    1. 场景描述 因兄弟项目中mysql有点扛不住了,要做sql优化,但是业务有点小复杂,优化起来有点麻烦(sql嵌套有点多),便想着用Mpp数据库Greenplum测试下,看性能和复杂度怎么样,趟趟水 ...

  2. 常用SQL操作(MySQL或PostgreSQL)与相关数据库概念

    本文对常用数据库操作及相关基本概念进行总结:MySQL和PostgreSQL对SQL的支持有所不同,大部分SQL操作还是一样的. 选择要用的数据库(MySQL):use database_name; ...

  3. 【PHP基础】常用mySQL语句以及WampServer2.2设置数据库默认编码

    一.WampServer2.2设置数据库默认编码(此部分转自http://www.cnsecer.com/5984.html) wamp下MySQL的默认编码是Latin1,不支持中文,要支持中文的话 ...

  4. 常用MySQL语句整合

    常用MySQL语句整合 1. MySQL服务的配置和使用 修改MySQL管理员的口令:mysqladmin –u root password 密码字符串 如:mysqldmin –u root pas ...

  5. Mysql 和 Postgresql(PGSQL) 对比

    Mysql 和 Postgresql(PGSQL) 对比 转载自:http://www.oschina.net/question/96003_13994 PostgreSQL与MySQL比较 MySQ ...

  6. PostgreSQL和Greenplum、Npgsql

    PostgreSQL和Greenplum.Npgsql 想着要不要写,两个原因“懒”和“空”.其实懒和空也是有联系的,不是因为懒的写,而是因为对PostgreSQL和Npgsql的知识了解匮乏,也就懒 ...

  7. 对Oracle 、SQL Server、MySQL、PostgreSQL数据库优缺点分析

    对Oracle .SQL Server.MySQL.PostgreSQL数据库优缺点分析 Oracle Database Oracle Database,又名Oracle RDBMS,或简称Oracl ...

  8. SQLite vs MySQL vs PostgreSQL:关系型数据库比较

    自1970年埃德加·科德提出关系模型之后,关系型数据库便开始出现,经过了40多年的演化,如今的关系型数据库种类繁多,功能强大,使用广泛.面对如此之多的关系型数据库,我们应该如何权衡找出适合自己应用场景 ...

  9. 去 IOE,MySQL 完胜 PostgreSQL

    本文转载自: http://www.innomysql.net/article/15612.html (只作转载, 不代表本站和博主同意文中观点或证实文中信息) 前言 上周参加了2015年的中国数据库 ...

随机推荐

  1. DAY10、函数的参数

    一.实参:为形参传递值 调用函数时,实参可以由常量,变量,表达式三种的组合 1.位置实参:必须按照位置的顺序,从左到右为形参传递值 fn1(10, 20, 30) fn1(30, 20, 10) 2. ...

  2. 转 spring注解式参数校验

    转自: https://blog.csdn.net/jinzhencs/article/details/51682830 转自: https://blog.csdn.net/zalan01408980 ...

  3. Python——迭代器

    一.概述 迭代器是访问集合元素的一种方式.迭代器对象从集合的第一个元素开始访问,直到所有的元素被访问完结束.迭代器只能往前不会后退. 二.可迭代的对象 序列:字符串.列表.元组 非序列:字典.文件 三 ...

  4. Scrapy 框架 中间件,信号,定制命令

    中间件 下载器中间件 写中间件 from scrapy.http import HtmlResponse from scrapy.http import Request class Md1(objec ...

  5. 帝国cms更新报错解决办法

    帝国cms更新,经常会报以下的错误: PHP Warning:  array_merge(): Argument #2 is not an array in D:\wwwroot\www.536831 ...

  6. TOMCAT ---> servlet概念

    1 TOMCAT ---> servlet概念 2 TOMCAT 目录结构 (各个文件夹都存放什么东西) 3 TOMCAT 程序的层级 web | |---- js,jsp,html,css ( ...

  7. Java NIO系列教程(一) Java NIO 概述

    <I/O模型之四:Java 浅析I/O模型> 一.阻塞IO与非阻塞IO 阻塞IO: 通常在进行同步I/O操作时,如果读取数据,代码会阻塞直至有 可供读取的数据.同样,写入调用将会阻塞直至数 ...

  8. Matlab中hold on与hold off的用法

    摘录自:https://blog.csdn.net/smf0504/article/details/51830963 https://www.cnblogs.com/shuqingstudy/p/48 ...

  9. CentOS7部署Dotnet Core2.1

    前言 笔者在毫无Linux部署.net core的经验下,第一次用了15分钟完成部署,第二次在生产环境用了5分钟.下文将说明如何在CentOS7下完成.NetCore2.1的部署,包括如何创建ASP. ...

  10. Android应用程序国际化

    前情提要 在Android应用程序中, 可以轻松更改语言, 以适应国际化标准 一些用户拥有多种语言习惯, 因此, 应用程序不能依赖设备默认语言环境, 必须提供更改显示语言的程序功能 本文章探寻持久化语 ...