sql语句的group by与having子句
1、获取当前时间
select current_timestamp;
返回形如'2019-01-08 14:14:10.209'的timestamp。如果想要获取yyyy-MM-dd HH:mm:ss格式的字符串,则需要用date_format。
如select date_format(current_timestamp, 'yyyy-MM-dd HH:mm:ss'); 返回'2019-01-08 14:14:10'。
select current_date; 返回形如'2019-01-08'的date
2、date_format 返回指定格式字符串。第一个参数是timestamp类型,或者string类型
如select date_format(current_timestamp, 'yyyyMMdd'); 返回'20190108'
select date_format(current_date, 'yyyyMMdd'); 返回'20190108'
select date_format('2019-01-08', 'yyyyMMdd'); 返回'20190108'
select date_format('2019-01-08 12:00:00', 'yyyyMMdd'); 返回'20190108'
3、日期加减
date_add(date/timestamp, int),返回date类型
如select date_add(current_timestamp, 1); 返回形如'2019-01-09'的date。
4、if (boolean condition, T valueTrue, T valueFalseOrNull)
如select if (1 < 2, 1, 2); 返回1
5、nvl(T value, T default_value)
如select nvl(null, 1); 返回1
6、greatest(T v1, T v2)、least(T v1, T v2),返回最大值、最小值,会忽略null
7、取字符串长度 length
如select length('abc'); 返回3
8、去左右空格 trim
如select trim(' abc '); 返回'abc'
9、字符串截取
substring、substr,用法完全一样,可以传两个参数或者三个参数
不同寻常的是,这里的索引从1开始。如
select substring('abc', 1); 返回'abc'
select substring('abc', 1, 1); 返回'a'
10、字符串拼接
concat
如select concat('a', 'b', 'c'); 返回'abc'
11、字符串转大小写
如select upper('abc'); 返回'ABC'
如select lower('ABC'); 返回'abc'
12、类型转换 cast,用法是cast(value as type)
①tinyint、smallint、int、bigint、float、double、string间相互转换
如select cast(30 as string); 返回'30'
select cast('30' as int); 返回30
②date、timestamp、string间相互转换
如select cast(current_timestamp as string); 返回'2019-01-09 10:48:17.319'
select cast(current_date as string); 返回'2019-01-09'
select cast('2019-01-09 10:48:17' as timestamp); 返回'2019-01-09 10:48:17.0'的timestamp
select cast('2019-01-09 10:48:17' as date); 返回'2019-01-09'的date
sql语句的group by与having子句的更多相关文章
- (转载)SQL语句中Group by语句的详细介绍
转自:http://blog.163.com/yuer_d/blog/static/76761152201010203719835 SQL语句中Group by语句的详细介绍 ...
- [转]SQL语句:Group By总结
1. Group By 语句简介: Group By语句从英文的字面意义上理解就是“根据(by)一定的规则进行分组(Group)”.它的作用是通过一定的规则将一个数据集划分成若干个小的区域,然后针对若 ...
- 转:sql语句中GROUP BY 和 HAVING和使用 count()
在开发时,我们经常会遇到以“累计(count)”或是“累加(sum)”为条件的查询.比如user_num表: id user num 1 a 3 2 a 4 3 b 5 4 b 7 例1:查询出现 ...
- SQL语句:Group By总结
1. Group By 语句简介: Group By语句从英文的字面意义上理解就是"根据(by)一定的规则进行分组(Group)".它的作用是通过一定的规则将一个数据集划分成若干个 ...
- sql语句的group by 与 inner join
一.理解group by和聚合函数 先来看下表1,表名为test: 表1 执行如下SQL语句: 1 2 SELECT name FROM test GROUP BY name 你应该很容易知道运行的结 ...
- sqlite sql语句关键字GROUP BY的理解
第一遍看GROUP BY的介绍时,没看懂. SQLite 的 GROUP BY 子句用于与 SELECT 语句一起使用,来对相同的数据进行分组.在 SELECT 语句中,GROUP BY 子句放在 W ...
- sql语句中GROUP BY 和 HAVING的使用 count()
在介绍GROUP BY 和 HAVING 子句前,我们必需先讲讲sql语言中一种特殊的函数:聚合函数, 例如SUM, COUNT, MAX, AVG等.这些函数和其它函数的根本区别就是它们一般作用在多 ...
- LINQ体验(7)——LINQ to SQL语句之Group By/Having和Exists/In/Any/All/Contains
我们继续讲解LINQ to SQL语句,这篇我们来讨论Group By/Having操作符和Exists/In/Any/All/Contains操作符. Group By/Having操作符 适用场景 ...
- SQL语句之Group By
1. Group By 语句简介: Group By语句从英文的字面意义上理解就是“根据(by)一定的规则进行分组(Group)”.它的作用是通过一定的规则将一个数据集划分成若干个小的区域,然后针对若 ...
随机推荐
- Chapter 21_2 模式匹配函数
基础函数比较简单,就是几个普通的函数string.byte.string.char.string.rep.string.sub.string.format还有大小写转换函数upper和lower. 接 ...
- anroid平台指纹方案
神盾的FingerPrint方案 在Java层,神盾主要提供如下几个包: egistec.fingerauth.api.FPAuthListeners; egistec.fingerauth.api. ...
- android自定义控件,其三个父类构造方法有什么区别
android自定义控件时,通常需要重写父类构造函数.这三个够找函数具体啥时调用? public View (Context context) 是在java代码创建视图的时候被调用,如果是从xml填充 ...
- 关于去除input type='file'改变组件的默认样式换成自己需要的样式的解决方案
在工作中时常会遇到如需要上传功能的按钮,而不像需要系统默认的样式时候,可以采取以下的解决方案: <img onclick="getElementById('file').click() ...
- Javascript Date 判断输入日期是否正确
JavaScript的Date对象有容错性,可将随意给定的日期的年月日自动生成正确的日期时间 //JavaScript中Date对象容错性 function dateCheck(){ var date ...
- Framebuffer的配置及应用——先转载留着,以后一定要弄懂
http://blog.csdn.net/tju355/article/details/6881389 借助于framebuffer,我们能够在console下面作很多事情.首先下载framebu ...
- 记一次-angular-数字格式化
一个收费功能模块,需要做数据验证. input标签的ng-model的数据格式化 <input type="number" class="form-control& ...
- sdk是啥
SDK 英文名称 software development kit ,即 软件开发工具包,就好第三方服务商提供的实现软件某功能的工具包
- L3-001. 凑零钱
L3-001. 凑零钱 题目链接:https://www.patest.cn/contests/gplt/L3-001 动态规划 这道题一看就知道应该用背包思想来做,不过想了好久没什么思路(dp实在是 ...
- Linux的cron和crontab
一 cron crond位于/etc/rc.d/init.d/crond 或 /etc/init.d 或 /etc/rc.d /rc5.d/S90crond,最总引用/var/lock/subsys/ ...