首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    带你学MySQL系列 | 这份MySQL函数大全,真的超有用!

    1.MySQL中关于函数的说明 2.单行函数分类 3.字符函数 1)length(str):获取参数值的字节个数; 2) concat(str1,str2,…):拼接字符串; 3)upper(str):将字符中的所有字母变为大写; 4)lower(str):将字符中所有字母变为小写; 5)substr(str,start,[len]):从start位置开始截取字符串,len表示要截取的长度; 6)instr(str,要查找的子串):返回子串第一次出现的索引,如果找不到,返回0; 7)trim(str):去掉字符串前后的空格; 8)lpad(str,len,填充字符):用指定的字符,实现对字符串左填充指定长度; 9)rpad(str,len,填充字符):用指定的字符,实现对字符串右填充指定长度; 10) replace(str,子串,另一个字符串):将字符串str中的字串,替换为另一个字符串; 4.数学函数 1)round(x,[保留的位数]):四舍五入; 2)ceil(x):向上取整,返回>=该参数的最小整数。(天花板函数) 3)floor(x):向下取整,返回<=该参数的最大整数。(地板函数) 4)truncate(x,D):截断; 5)mod(被除数,除数):取余; 5.日期时间函数 1)now():返回系统当前的日期和时间; 2)curdate():只返回系统当前的日期,不包含时间; 3)curtime():只返回系统当前的时间,不包含日期; 4)获取日期和时间中年、月、日、时、分、秒; 5)weekofyear():获取当前时刻所属的周数; 6)quarter():获取当前时刻所属的季度; 7)str_to_date():将日期格式的字符串,转换成指定格式的日期; 8)date_format():将日期转换成日期字符串; 9)date_add() + interval:向前、向后偏移日期和时间; 10)last_day():提取某个月最后一天的日期; 11)datediff(end_date,start_date):计算两个时间相差的天数; 12)timestampdiff(unit,start_date,end_date):计算两个时间返回的年/月/天数; 6.其它常用系统函数 7.流程控制函数 1)if函数:实现if-else的效果; 2)ifnull函数:判断值是否为null,是null用指定值填充; 3)case…when函数的三种用法; ① case … when用作等值判断的语法格式; ② case … when用作区间判断的语法格式; ③ case…when与聚合函数的联用 8.聚合函数 1)聚合函数的功能和分类; ① 聚合函数的功能; ② 聚合函数的分类; 2)聚合函数的简单使用; 3)五个聚合函数中传入的参数,所支持的数据类型有哪些? ① 测试数据; ② sum()函数和avg()函数:传入整型/小数类型才有意义; ③ max()函数和min()函数:传入整型/小数类型、日期/时间类型意义较大; ④ count()函数:可以传入任何数据类型,但是碰到null要注意; ⑤ count()函数碰到null值需要特别注意; ⑥ count(1),count(0)表示的是啥意思呢? ⑦ count(*)计数的效率问题; 4)聚合函数和group by的使用“最重要”;

    04

    数据分析小结:使用流计算 Oceanus(Flink) SQL 作业进行数据类型转换

    在这个数据爆炸的时代,企业做数据分析也面临着新的挑战, 如何能够更高效地做数据准备,从而缩短整个数据分析的周期,让数据更有时效性,增加数据的价值,就变得尤为重要。 将数据从来源端经过抽取(extract)、转换(transform)、加载(load)至目的端的过程(即 ETL 过程),则需要开发人员则需要掌握 Spark、Flink 等技能,使用的技术语言则是 Java、Scala 或者 Python,一定程度上增加了数据分析的难度。而 ELT 过程逐渐被开发者和数据分析团队所重视,如果读者已经非常熟悉 SQL,采用 ELT 模式完成数据分析会是一个好的选择,比如说逐渐被数据分析师重视的 DBT 工具,便利用了 SQL 来做数据转换。DBT 会负责将 SQL 命令转化为表或者视图,广受企业欢迎。此外使用 ELT 模式进行开发技术栈也相对简单,可以使数据分析师像软件开发人员那样方便获取到加工后的数据。

    03

    Java|Java8 新特性

    前言 Java8已经出现了很久了,但是呢,还是有很多人都还在习惯使用以前的来版本JDK,或者是以前老版本的编程方式。通过一段时间对Java8新特性的学习之后,自己也深受感触,原来java8版本写代码可以这么简洁。Java8最主要的就是给我们编程的过程带来了很多便利,不仅仅是代码量少。更多的还是让程序更简洁,减少代码冗余。Java8新特性中有几个比较主要的特性,Lambda 表达式、函数式接口、方法引用和几个新增库Stream API、Optional类等。 接下来就是对自己的学习内容做一个总结。 Lambda 表达式 2.1 Lambda表达式简介 Lambda 表达式其实就是一种匿名函数,在这之前大家可能还接触过匿名内部类,虽然也是一种匿名函数,但是它并没有Lambda表达式那么简洁,Lambda表达式的特点就是可以传递,在使用Lambda表达式的时候我们可以将代码像数据一样传递。使用Lambda表达式能够极大的减少我们代码的冗余,而且使用也相当的方便。熟练之后会大大加快我们写代码的速度。 2.2 java8的方法与老版本的对比 首先我们来尝试着找出公司员工年龄大于35岁的所有员工,这个问题都不是很难吧。我们用不同的方法来实现一下,我先给出几个不同的方法直接看看效果。 首先我们应该做的是创建员工的数据,先创建一个Staff类来代表员工,并且使用构造函数来创建员工的集合。第一种方法来看看我使用的最常规的方法: public List<Staff> getStaffs(List<Staff> staffs) { List<Staff> stas=new ArrayList<>(); for(Staff sta:staffs){ if (sta.getAge()>=35){ stas.add(sta); } } return stas; } @Test public void test1(){ List<Staff> list = getStaffs(staffs); for (Staff staf:list) { System.out.println(staf); } } 只看一种方法可能没有什么感觉,那么再看看第二种方法试试呢。 这种方法也叫策略设计模式,我们需要写一个接口,然后实行这个接口,最后是调用接口。这种方法看起来就比前面的那种更有层次,而且假如又需要查找员工工资大于5000的员工的话,我们就可以重新写一个类来实现接口就好了,下面来看看代码。 public List<Staff> filterStaff(List<Staff> list,MyPredicate<Staff> mp){ List<Staff> staffs=new ArrayList<>(); for (Staff staff:list) { if (mp.test(staff)){ staffs.add(staff); } } return staffs; } @Test public void test2(){ List<Staff> list = filterStaff(staffs,new filterStaffByAge()); for (Staff staf:list) { System.out.println(staf); } } 第三种方法是使用匿名内部类的方法,其实也是和第二种方法是差不多的。 public void test3(){ List<Staff> list=filterStaff(staffs, new MyPredicate<Staff>() { @Override public boolean test(Staff staff) { return staff.getAge()>=35; } }); for (Staff staf:list) { System.out.println(staf); } } 这些方法都是java8之前可以使用的一些方法,那么java8以后有哪些方法呢?前面的方法看了之后有没有

    02
    领券