根据条件从一个list中取元素 放到另一个list中
新建一个map 根据条件遍历 list 获取 元素放到map中 再把map添加到新的list中
例子:
List>list=gunPayDao.getPayTodayWayList(body);
List>sole=gunPayDao.getPayTodayWayListMax(body);
List>all=newArrayList<>();
List>self=newArrayList<>();
//格式化金额保留两位小数
DecimalFormatdf=newDecimalFormat("####.##");
for(Mapmap:list) {
total+=Double.parseDouble(map.get("value").toString());//获取总支付额
if(("2".equals(map.get("pmcode")+"")&&("1".equals(map.get("pmsubcode")+"") ||"4".equals(map.get("pmsubcode")+"") ||"29".equals(map.get("pmsubcode")+"") ||"30".equals(map.get("pmsubcode")+""))||("1".equals(map.get("pmcode")+"")||"20".equals(map.get("pmsubcode")+"") ) )) {
all.add(map);
continue;
}
self.add(map);
}
//其他支付方式总额
Doublevolume= 0.0;
for(Mapmap:self) {
volume+= Double.parseDouble(map.get("value")+"");
}
Mapmap=newHashMap<>();
map.put("name","其他");
map.put("others",self);
map.put("value",df.format(volume));
all.add(map);
Mapresult=newHashMap<>();
result.put("total",df.format(total));
result.put("all",all);
result.put("sole",sole);
List>data=newArrayList>();
data.add(result);
returndata;
给表里添加数据
INSERT into student_test (name,course,score) VALUES('张三','语文',81);
INSERT into student_test (name,course,score) VALUES('张三','数学',75);
INSERT into student_test (name,course,score) VALUES('李四','语文',76);
INSERT into student_test (name,course,score) VALUES('李四','数学',81);
INSERT into student_test (name,course,score) VALUES('王五','语文',85);
INSERT into student_test (name,course,score) VALUES('王五','数学',83);
DELETE FROM student_test WHERE name = '张三' 删除表中名字是张三的数据
TRUNCATE student_test; 清空表
SELECT DISTINCT`name`,
CASE WHEN name = '张三' THEN (select score from student_test where course='数学' and name='张三')
WHEN name = '李四' THEN (SELECT score FROM student_test WHERE name = '李四' AND course = '语文')
ELSE (SELECT score FROM student_test WHERE name = '王五' AND course = '语文')
END as aaa
FROM student_test ; 获取不同学生某课成绩
SELECT st.`name` FROM student_test st GROUP BY st.`name` HAVING MIN(st.score)>80;
获取成绩大于80的学生名单
SpringMVC运行原理
客户端请求提交到DispatcherServlet
(前台控制器)
由DispatcherServlet控制器查询HandlerMapping(处理器映射),找到并分发到指定的Controller中。
Controller调用业务逻辑处理后,返回ModelAndView
DispatcherServlet查询一个或多个ViewResoler视图解析器,找到ModelAndView指定的视图
视图负责将结果显示到客户端
Java序列化是指把Java对象转换为字节序列的过程;而Java反序列化是指把字节序列恢复为Java对象的过程Serializable接口
Spring是一个轻量级的控制反转(IoC)和面向切面(AOP)的容器框架。
@Component 把对象加入ioc容器,对象引用名称是类名,第一个字母小写
@Component(“name”) 把指定名称的对象,加入ioc容器
@Repository 主要用于标识加入容器的对象是一个持久层的组件(类)
@Service 主要用于标识加入容器的对象是一个业务逻辑层的组件
@Controller 主要用于标识加入容器的对象是一个控制层的组件
@Resource 注入属性(DI), 会从容器中找对象注入到@Resource修饰的对象上
@Autowired 注入属性(DI), 会从容器中找对象注入到@Autowired修饰的对象上
AOP是Aspect Oriented Programming的缩写,意思是面向切面编程
从OOP角度分析,我们关注业务的处理逻辑,是属于纵向的行为,从AOP角度分析,我们关注对象行为发生时的问题,是属于横向的问题.
AOP就是把贯穿在各个模块之间相同的功能抽取出来,然后封装成一个面.
AOP的作用: 1.监控函数的调用 2.捕获异常的发生
实际应用于:事务,安全,日志等横切关注
两种方式实现AOP的方式:
1.JDK提供的动态代理实现,Spring规定对于有接口的类用JDK,对于无接口和抽象类使用cglib,虽然cglib均可代理,但是cglib复杂,效率低,而且cglib中代理的类中不能有final的方法.
2.其中对于AOP来说,他也可以理解为一个面,在这个面里面我们利用代理类来找目标对象是什么,拦截那些方法,然后在这些方法的前后也可以执行一些操作.
IOC(Inversion of control):控制反转,依赖注入
概念:控制权有对象本身专享容器,由容器根据配置文件去创建实例,并创建各个实例之间的关系,则通俗的说,对象的创建再也不需要程序员来管理,而是可以有spring容器来进行创建和销毁,我们只需要关注业务逻辑.
依赖IOC容器并管理bean,有两种,一种是BeanFactory,另一种是ApplicationContext,但是APPlicationContext extends BeanFactory.
核心:Spring中,bean工厂创建的各个实例称作bean.