解忧杂货铺---致java程序员

2023-10-14 22:08

本文主要是介绍解忧杂货铺---致java程序员,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1. myslq中count(*)、count(1)的区别
idnameage
1tom16
jack
roles18

如上表:
count(age)=2;(计算age字段值不为空的记录数)
count(*)=3;(计算只要有一个字段值不为空的记录数)
count(1)=1;(计算第一个字段值不为空的记录数)
所以,这也是为什么count(1)的速度要比count(*)快的原因。因为count(1)只需要计算第一列就好了。

2. myslq中 if 的使用
idstatus
15
210
315
410

sql:

select count(if(e.status = 5,1,null)) as '状态为5的数量', count(if(e.status = 10,1,null)) as '状态为10的数量'from employee e;

sql解析:计算状态为5的数量;
count(if(e.status = 5,1,null)) 意思是:如果状态等于5,那么返回1,否则返回null
结果:

状态为5的数量状态为10的数量
12

ps:其实还可以这样:if中加or

select count(if(e.status = 5,1,null)) as '状态为5的数量', count(if(e.status = 10 or e.status = 15,1,null)) as '状态为10或15的数量'from employee e;
3. myslq中 distinct 的使用

表:

idnamesalary
1tom6000.00
2jack7000.00
3roles6000.00
sql解析
count(distinct(id))返回id不同的记录数
select distinct name from user返回name不同的记录
select distinct id,name from user过滤id和name都重复的记录

如上,第二第三条语句只会返回过滤的字段值,啥意思呢?
就是第二条sql只会显示name字段,第三条sql只会显示id,name字段。

有的时候我们既要按照要求过滤重复记录,又要显示所有的字段该怎么办呢?有的时候我们既要按照要求过滤重复记录,又要显示所有的字段该怎么办呢?这个时候我们一般可以使用group by分组来达到去重的效果。

需求:按照salary去重,同时显示其他字段。
解析:select * from employee where id in (select max(id) from employee group by salary);
这样就可以达到我们的目的啦!

4. myslq中 使用循环插入大量数据

当我们在测试的时候想要插入大量数据怎么办?使用JDBC在java中for循环?麻烦!
直接在sql使用存储过程插入就好啦。
例:

DROP PROCEDURE if exists insertdata;
delimiter //
CREATE PROCEDURE insertdata() 
begin 
declare num int; 
set num=1; 
while num < 1000000 do 
insert into tabless (id,title, tel) values(num,concat("title", num),concat("134", num)); 
set num=num+1;
end while;
end//
delimiter;
call insertdata();

主要sql解析:

行号解析
1如果insertdata程序存在则删除(注意:如果PROCEDURE名字一样,则每次使用都要删除掉之前的PROCEDURE,否则报错)
2定界符,sql中是以’;'结尾的,遇到;表示这条语句已经到此为止了。delimiter //的作用就是告诉myslq解释器,遇到// 才表示此语句到此为止。
3创建一个名为:insertdata 的 PROCEDURE
5declare 声明字段类型
最后一行call 调用存储过程,就相当于java调用方法一样(可以这样理解)
5. myslq跨库查询

以前一直觉得我们在配置文件中指定了在哪个数据库就只能在哪个数据库做操作,后面发现只要能够连接上myslq的服务就可以对服务上的所有的数据库做操作,尽管我们程序的配置文件不是指定的该数据库也可以。

cabinet-other库cabinet-system库
bas_case_type表bus_operation_record表
bas_res表bus_cabinet_landing表
bas_res_details表

如上:两个数据库、共5张表
sql:

select count(DISTINCT(rd.res_id)) from `cabinet-other`.bas_case_type ctINNER JOIN `cabinet-other`.bas_res r on ct.identifying=r.types_of_casesinner JOIN `cabinet-other`.bas_res_details rd on rd.res_id=r.idINNER JOIN `cabinet-system`.bus_operation_record ord on ord.epcid=r.epcidinner join `cabinet-system`.bus_cabinet_landing clg on clg.id = ord.cabinet_landing_codewhere r.delete_flag='0' AND ord.flag='0'

跨库查询,只需要在原本的表名之前加上数据库的名称就可以了…

6. mysql UNION 与 UNION ALL的区别

myslq 中 union 与 union all 都是用来将多个结果集合并成一个结果集。
例:
表1:

idname
1jack
2tom

表2:

idname
1jack
2roles

使用UNION 合并的结果是:UNION会自动压缩结果中的重复结果,同时进行默认规则的排序。

idname
1jack
2tom
3roles

使用UNION ALL合并的结果是:UNION ALL则是将全部的结果都展示出来,不管有没有重复,不进行排序。

idname
1jack
2tom
3jack
4roles

ps:使用union和union all必须保证各个select
集合的结果有相同个数的列,并且每个列的类型是一样的。但列名则不一定需要相同,oracle会将第一个结果的列名作为结果集的列名。mysql中应该也是一样的

7.mysql将数据库表中的数字以百分号的形式展现

在做数据提取时,经常会遇到数据所占百分比的问题,在SQL中有专门的语句可以实现。

语法:select concat(round(值A/值B*100,m),’%’)
round函数返回数字表达式并四舍五入为指定的长度或精度。ROUND的格式:ROUND(p1,p2,p3),其作用是取四舍四入值
P1:要被四舍五入的数字
P2:保留的小数位数
P3:如果为0或不输入,则表示进P1进入四舍五入,如ROUND(123.86,1) =123.9
如果P3是不为0的数,则对P1进行截断,可以理解为不四舍五入 ROUND(123.86,1,1)=123.8

当p2非正值时,例如,ROUND(123.86,-1) =120;ROUND(123.86,0) =124;ROUND(123.86,-2) =100;ROUND(123.86,-3) =0

7.js判断数据是不是JSON格式
function isJSON(str) {if (typeof str == 'string') {try {var obj=JSON.parse(str);if(typeof obj == 'object' && obj ){return true;}else{return false;}} catch(e) {console.log('error:'+str+'!!!'+e);return false;}}console.log('It is not a string!')
}
8. Redis中的数据类型

我们都知道Redis中有5中数据类型:string、list、set、hash、zset;殊不知,Redis中还可以存放字节类型的数据,还可以设置key为自增长

我们使用RedisTemplate就是将数据装换成字节然后再存储到Redis中的。

RedisAtomicLong entityIdCounter = new RedisAtomicLong(key, redisTemplate.getConnectionFactory());
Long increment = entityIdCounter.incrementAndGet();

使用RedisAtomicLong类获取key的自增值,incrementAndGet()方法是先自增再获取,也有先获取再自增的方法getAndIncrement();这两个方法就相当于是++i与i++一样。
参数1:key;参数二:redis连接工厂。

也可以按照一定的步长自增:

RedisAtomicLong entityIdCounter = new RedisAtomicLong(key, redisTemplate.getConnectionFactory());
Long increment = entityIdCounter.addAndGet(num);//自增量,比如一次自增2
9. Redis数据设置过期时间

自己写的工具类RedisService.java中的方法:

/*** 设置对象* @param key* @param object* @param expireTime    失效时间:null 永不失效/不修改剩余失效时长;其他数值表示失效时长(秒)* @return*/public <K> void setData(String key, K object, Integer expireTime){ValueOperations<String, K> option = redisTemplate.opsForValue();if(expireTime!=null) {// 设置数据option.set(key, object);// 设置失效时间redisTemplate.expire(key, expireTime, TimeUnit.SECONDS);} else {// 删除数据redisTemplate.delete(key);// 设置数据option.set(key, object);}}
10. Redis分布式锁实现
try {// 获取分布式锁Boolean lock = redisTemplate.opsForValue().setIfAbsent("kill_" + id, true);if(lock) {// 获取锁成功// 业务逻辑...}
} catch (Exception e) {throw new RuntimeException(e);
} finally { // 释放分布式锁(避免死锁)redisTemplate.delete("kill_" + id);
}
11. Redis中的数据到了过期时间就立即删除吗?

Redis中有三种删除过期数据的方式。
方式一:立即删除;但是这样会存在一个问题,就是:如果这个时候CPU很忙,而同时间过期的数据又不少,这样就更加的增加了CPU的负担;
方式二:懒惰删除;到了过期时间不立即删除,而是等下次用到的时候再查询该数据的过期时间,如果过期则删除;
方式三:定时删除;
Redis是方式二和方式三结合使用。

12. 项目设置时区
// 设置为UTC世界时
System.setProperty("user.timezone", "UTC");
TimeZone.setDefault(TimeZone.getTimeZone("UTC"));
13. IDEA代码设置代理【FQ】
// System.setProperty("proxyHost", "127.0.0.1");
// System.setProperty("proxyPort", "10809");

在这里插入图片描述

这篇关于解忧杂货铺---致java程序员的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/213451

相关文章

SpringBoot中四种AOP实战应用场景及代码实现

《SpringBoot中四种AOP实战应用场景及代码实现》面向切面编程(AOP)是Spring框架的核心功能之一,它通过预编译和运行期动态代理实现程序功能的统一维护,在SpringBoot应用中,AO... 目录引言场景一:日志记录与性能监控业务需求实现方案使用示例扩展:MDC实现请求跟踪场景二:权限控制与

Java NoClassDefFoundError运行时错误分析解决

《JavaNoClassDefFoundError运行时错误分析解决》在Java开发中,NoClassDefFoundError是一种常见的运行时错误,它通常表明Java虚拟机在尝试加载一个类时未能... 目录前言一、问题分析二、报错原因三、解决思路检查类路径配置检查依赖库检查类文件调试类加载器问题四、常见

Java注解之超越Javadoc的元数据利器详解

《Java注解之超越Javadoc的元数据利器详解》本文将深入探讨Java注解的定义、类型、内置注解、自定义注解、保留策略、实际应用场景及最佳实践,无论是初学者还是资深开发者,都能通过本文了解如何利用... 目录什么是注解?注解的类型内置注编程解自定义注解注解的保留策略实际用例最佳实践总结在 Java 编程

Java 实用工具类Spring 的 AnnotationUtils详解

《Java实用工具类Spring的AnnotationUtils详解》Spring框架提供了一个强大的注解工具类org.springframework.core.annotation.Annot... 目录前言一、AnnotationUtils 的常用方法二、常见应用场景三、与 JDK 原生注解 API 的

Java controller接口出入参时间序列化转换操作方法(两种)

《Javacontroller接口出入参时间序列化转换操作方法(两种)》:本文主要介绍Javacontroller接口出入参时间序列化转换操作方法,本文给大家列举两种简单方法,感兴趣的朋友一起看... 目录方式一、使用注解方式二、统一配置场景:在controller编写的接口,在前后端交互过程中一般都会涉及

Java中的StringBuilder之如何高效构建字符串

《Java中的StringBuilder之如何高效构建字符串》本文将深入浅出地介绍StringBuilder的使用方法、性能优势以及相关字符串处理技术,结合代码示例帮助读者更好地理解和应用,希望对大家... 目录关键点什么是 StringBuilder?为什么需要 StringBuilder?如何使用 St

使用Java将各种数据写入Excel表格的操作示例

《使用Java将各种数据写入Excel表格的操作示例》在数据处理与管理领域,Excel凭借其强大的功能和广泛的应用,成为了数据存储与展示的重要工具,在Java开发过程中,常常需要将不同类型的数据,本文... 目录前言安装免费Java库1. 写入文本、或数值到 Excel单元格2. 写入数组到 Excel表格

Java并发编程之如何优雅关闭钩子Shutdown Hook

《Java并发编程之如何优雅关闭钩子ShutdownHook》这篇文章主要为大家详细介绍了Java如何实现优雅关闭钩子ShutdownHook,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起... 目录关闭钩子简介关闭钩子应用场景数据库连接实战演示使用关闭钩子的注意事项开源框架中的关闭钩子机制1.

Maven中引入 springboot 相关依赖的方式(最新推荐)

《Maven中引入springboot相关依赖的方式(最新推荐)》:本文主要介绍Maven中引入springboot相关依赖的方式(最新推荐),本文给大家介绍的非常详细,对大家的学习或工作具有... 目录Maven中引入 springboot 相关依赖的方式1. 不使用版本管理(不推荐)2、使用版本管理(推

Java 中的 @SneakyThrows 注解使用方法(简化异常处理的利与弊)

《Java中的@SneakyThrows注解使用方法(简化异常处理的利与弊)》为了简化异常处理,Lombok提供了一个强大的注解@SneakyThrows,本文将详细介绍@SneakyThro... 目录1. @SneakyThrows 简介 1.1 什么是 Lombok?2. @SneakyThrows