超级简单的SSM框架(全注解,源码+分析,看一眼就会)

news2024/11/20 7:06:22

1.什么是SSM?

SSM是Spring、SpringMVC、Mybatis的框架整合。

2.什么是Spring?

Spring是一个轻量级的控制反转(IoC)和面向切面(AOP)的容器框架。

优点:

1.通过Spring的IOC特性,将对象之间的依赖关系交给了Spring控制,方便解耦,简化了开发。
2.通过Spring的AOP特性,很容易实现事务,日志,权限的控制。
3.提供了对其他优秀开源框架的集成支持。
4.低侵入式。

3.什么是Spring Mvc?

Spring MVC属于Spring Framework的后续产品,已经融合在Spring Web Flow里面,它原生支持的Spring特性,让开发变得非常简单规范。Spring MVC 分离了控制器、模型对象、分派器以及处理程序对象的角色,这种分离让它们更容易进行定制。

优点:

1.pringMVC是使用了MVC设计思想的轻量级web框架,对web层进行解耦,是的我们开发更简洁。
2.与Spring无缝衔接。
3.灵活的数据验证,格式化,数据绑定机制。

4.什么是Mybatis?

MyBatis本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了google code,并且改名为MyBatis 。MyBatis是一个基于Java的持久层框架。iBATIS提供的持久层框架包括SQL Maps和Data Access Objects(DAO)MyBatis消除了几乎所有的JDBC代码和参数的手工设置以及结果集的检索。MyBatis使用简单的XML或注解用于配置和原始映射,将接口和Java的POJOs(Plain Old Java Objects,普通的 Java对象)映射成数据库中的记录。可以这么理解,MyBatis是一个用来帮你管理数据增删改查的框架。

优点:

1.sql写在xml文件中,便于统一管理和优化,解除sql和程序代码的耦合。
2.提供映射标签,支持对象和和数据库orm字段关系的映射,支持对象关系映射标签,支持对象关系的组建。
3.提供xml标签,支持编写动态sql。

缺点:

1.工作量较大,特别是在表的字段多,关联表多的情况下。
2.sql语句的编写依赖于数据库,移植性差。
3.不支持级联删除,级联更新,需要自己对表进行删除。

SSM框架就是把Spring、SpringMVC、Mybatis的集大成者,分为持久层、服务层、显示层、控制层,把它们的优点汇聚一身,实现代码的易维护,低耦合、高内聚。

案例(用户的增删改功能)

控制层

@Controller
public class UserController {

    @Autowired
    private UserService userService;

    @GetMapping(value = "/list")
    public String list(HttpSession session){
        List<User> users = userService.findAll();
        session.setAttribute("users",users);
        int recordsCount = userService.totalCount();
        session.setAttribute("count",recordsCount);
        return "userlist";
    }

    @GetMapping("/addUser")
    public String showAdd(){
        return "addUser";
    }

    @PostMapping("/addUser")
    public String showList(User user, HttpSession session){
        userService.insertOne(user);
        return list(session);
    }

    @GetMapping("/delUser")
    public String showList2(User user,HttpSession session){
        userService.deleteOne(user.getId());
        return list(session);
    }

    @GetMapping("/echo")
    public String echoUser(Integer id,Model model){
        User user = userService.findOne(id);
        model.addAttribute("user",user);
        return "updUser";
    }

    @PostMapping("/updUser")
    public String updUser(User user,HttpSession session){
        userService.updateOne(user);
        return list(session);
    }

}

持久层

@Repository
public interface UserDao {

    /**
     * 根据id查询学生信息
     */
    @Select("select * from user where id = #{id} and id is not null")
    public User findOne(Integer id);

    @Select("select * from user")
    public List<User> findAll();

    @Insert("insert into user values(null,#{username},#{phone},#{password},#{email})")
    public int insertOne(User user);

    @Select("<script>select * from user\n" +
            "<where>\n" +
            "   <if test=\"user.username != null and user.username != ''\">\n" +
            "       and username like #{user.username}\n" +
            "   </if>\n" +
            "   <if test=\"user.phone != null and user.phone != ''\">\n" +
            "       and phone = #{user.phone}\n" +
            "   </if>\n" +
            "   <if test=\"user.email != null and user.email != ''\">\n" +
            "       and email = #{user.email}\n" +
            "   </if>\n" +
            "</where>\n" +
            "</script>")
    public List<User> findAllByCondition(User user);

    @Delete("delete from user where id = #{id}")
    public int deleteOne(Integer id);

    @Update("update user set username=#{username},phone=#{phone},password=#{password},email=#{email} where id = #{id}")
    public int updateOne(User user);

    @Select("select count(*) from user")
    public int totalCount();

}

服务层

public interface UserService {
    public User findOne(Integer id);
    public boolean insertOne(User user);
    public List<User> findAllByCondition(User user);
    public boolean deleteOne(Integer id);
    public boolean updateOne(User user);
    public List<User> findAll();
    public int totalCount();
}

@Service
public class UserServiceImpl implements UserService {

    @Autowired
    private UserDao userDao;

    @Override
    public User findOne(Integer id) {
        return userDao.findOne(id);
    }

    @Transactional(rollbackFor = {Exception.class})
    @Override
    public boolean insertOne(User user) {
        return userDao.insertOne(user) > 0;
    }

    @Override
    public List<User> findAllByCondition(User user) {
        if (user.getUsername()!=null && user.getUsername().length()>0){
            user.setUsername("%"+user.getUsername()+"%");
        }
        return userDao.findAllByCondition(user);
    }

    @Transactional(rollbackFor = {Exception.class})
    @Override
    public boolean deleteOne(Integer id) {
        return userDao.deleteOne(id) > 0;
    }

    @Transactional(rollbackFor = {Exception.class})
    @Override
    public boolean updateOne(User user) {
        return userDao.updateOne(user) > 0;
    }

    @Override
    public List<User> findAll() {
        return userDao.findAll();
    }

    @Override
    public int totalCount() {
        return userDao.totalCount();
    }
}

 pojo类

@Data
@NoArgsConstructor
@AllArgsConstructor
@ToString
public class User {
    private Integer id;
    private String username;
    private String phone;
    private String password;
    private String email;
}

还有很多配置类的源码,这里不过多展示了。

效果图:

 

增删改已经全部显示完成。这就是优雅的SSM框架,非常的简单! 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/568805.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

基于关系抽取的相似度计算

文章目录 一、面向冶金设备运维履历的知识图谱构建与语义相似性度量研究二、KG中的实体相似度计算研究研究假设研究方法第一步&#xff1a;特征生成第二步&#xff1a;模型选择 三、基于司法案例知识图谱的类案推荐个人解惑 一、面向冶金设备运维履历的知识图谱构建与语义相似性…

叮咚买菜业绩大幅低于预期,2023年前景堪忧

来源l&#xff1a;猛兽财经 作者&#xff1a;猛兽财经 叮咚买菜2023年第一季度业绩低于预期 叮咚买菜&#xff08;DDL&#xff09;于5月12日公布了2023年第一季度财报。 财报显示&#xff0c;叮咚买菜的收入同比下降了-8%&#xff0c;从2022年第一季度的54.44亿元人民币下滑…

搭建Stm32遇到的问题汇总

问题一&#xff1a;右侧watch窗口无法显示数据动态变化 现象&#xff1a;在main循环中加入累加的数值都不变化 现象2&#xff1a;单步执行卡在如下函数 原因&#xff1a;一般是因为没有用微库进入半主机模式 解决措施&#xff1a; 措施一&#xff1a;打开勾选下面的。 措施二…

【HTTP】

目录 &#x1f3a8;1. HTTP 请求 &#x1f3f0;1.1 首行 &#x1f451;1.2 URL &#x1f6a9;1.3 Content-Type 和 Content-Length &#x1f34a;1.4 User-Agent &#x1f33d;1.5 Referer ⚽1.6 Cookie &#x1f369;2. HTTP 响应 &#x1f31e;2.1 HTTP 响应 首行…

软件工程学习1:软件项目项目管理

假设你被指派作为一个软件公司的项目负责人&#xff0c;任务是开发一个管理系统&#xff0c;人员规模大约为8人&#xff0c;人员角色应如何确定&#xff1f;应如何进行项目管理&#xff1f;&#xff08;从软件项目管理估算、软件规模、工作量估算、进度计划安排、软件过程模型等…

入行4年,跳槽2次,我好像摸透了软件测试这一行!

很多测试人在行业中摸爬滚打了很多年&#xff0c;时不时给身边新入职的伙伴们一些好的建议&#xff0c;对一部分刚入职起步的测试小白来说&#xff0c;这些建议都是让你少走弯路的捷径&#xff0c;废话不多说&#xff0c;让我们来了解一下&#xff0c;一位入行4年跳槽2次的老测…

JSONException: illegal identifier : \pos 1 异常报错问题

JSONException: illegal identifier : \pos 1 异常报错问题 1.常见情况&#xff1a;1.1 JSON 字符串格式不正确1.2 JSON 字符串中包含了非法字符1.3 解析 JSON 字符串的方式不正确 2.解决办法&#xff1a;2.1 工具类2.2 StringEscapeUtils.unescapeJava3. JSONObject.parseObje…

黑客入门教程从零基础入门到精通,看完这一篇就够了

学前感言: 1.这是一条坚持的道路,三分钟的热情可以放弃往下看了. 2.多练多想,不要离开了教程什么都不会了.最好看完教程自己独立完成技术方面的开发. 3.有时多google,baidu,我们往往都遇不到好心的大神,谁会无聊天天给你做解答. 4.遇到实在搞不懂的,可以先放放,以后再来解决…

Revit建模|怎么创建轴网标高?

大家好&#xff0c;这里是建模助手&#xff0c;今天给大家讲一讲怎么创建轴网标高。 标高用来定义楼层层高以及生成平面视图&#xff0c;轴网用于为构件定位&#xff0c;在Revit中轴网确定了一个不可见的工作平面&#xff0c;轴网编号以及标高符号样式均可定制修改。目前&…

每日练题---C语言

目录 前言&#xff1a; 一.求最小公倍数 1.1公式法 1.2遍历法 1.3乘除法 二.倒置字符串 前言&#xff1a; 今日份题目有&#xff1a;求两个整数的最小公倍数&#xff0c;求倒置字符串&#xff0c;。 一.求最小公倍数 牛客网链接&#xff1a;OJ链接 百度词条&#xff1a;…

Python自动化测试框架怎么搭建?完整框架源码给到你

目录 前言 搭建过程&#xff1a; 一阶段&#xff0c; 二阶段&#xff0c; 三阶段&#xff0c; 四阶段 下面具体的说一下搭建过程 一阶段&#xff1a; 二阶段&#xff1a; 三阶段&#xff1a; 四阶段 前言 背景&#xff1a;公司需要每一个项目组都搭建自己的一套自动…

Vue企业级项目开发思路,附带源码

项目的技术栈展示 以及项目的核心重点部分 项目搭建使用element实现首页布局 顶部导航菜单及与左侧导航联动的面包屑实现 封装一个ECharts组件 封装一个Form表单组件和Table表格组件 企业开发之权限管理思路讲解 项目搭建使用element实现首页布局 顶部导航菜单及与左侧导…

技术分享 | OB 慢查询排查思路

本文汇总了项目实践中前辈的经验和笔者的理解&#xff0c;旨在帮助初学 OceanBase&#xff08;以下简称 OB&#xff09;的工程师&#xff0c;快速解决 SQL 执行缓慢等性能问题。当遇到性能问题时&#xff0c;很多工程师可能会感到无从下手&#xff0c;本文将根据关键日志提供多…

14_Uboot图形化配置

目录 U-Boot图形化配置体验 make menuconfig过程分析 Kconfig语法简介 Mainmenu menu/endmenu条目 config条目 depends on和select choice/endchoice Menuconfig Comment Source 添加自定义菜单 U-Boot图形化配置体验 uboot或Linux内核可以通过输入"make menu…

计算机组成原理-存储系统-外部存储虚拟存储器

目录 一、外部存储 1.1磁盘组成 1.2性能指标 1.3磁盘地址 1.4硬盘的工作原理 1.5磁盘阵列 二、 固态硬盘SSD 三、虚拟存储器(存储系统详细知识点) 3.1 页式存储器 逻辑地址-》主存(物理)地址 加入块表(TLB)的转换过程 3.2 段式存储器 3.3 段页式存储器 一、外部存储 又称…

一个非系统工程师所关心的——Android开机流程

一、Loader层 1. Boot ROM: 上电后&#xff0c;BootRom会被激活&#xff0c;引导芯片代码开始从预定义的地方&#xff08;固化在ROM&#xff09;开始执行&#xff0c;然后加载引导程序到RAM。 2. Boot Loader引导程序 Android是基于Linux系统的&#xff0c;它没有BIO…

路由器端口映射-原理+图解

文章目录 1. 前言2. 内部服务器3. 内网IP3.1 含义3.2 查询内网IP方法3.3 直观法判断内网IP 4. 内部端口5. 外部端口6. 远程桌面连接7. 端口映射原理图8. 欢迎纠正~ 1. 前言 端口映射就是可将N台主机的内网IP地址映射成一个公网IP地址&#xff0c;从而让外网可以访问到局域网内…

Linux 学习笔记(九):基于 TSS 的进程切换

一、TSS 基本概念 1、什么是 TSS &#xff1f; TSS&#xff08;Task State Segment&#xff09;即任务状态段。具体的说&#xff0c;在设计 “Intel 架构”&#xff08;即 x86 系统结构&#xff09;时&#xff0c;每个任务&#xff08;进程or线程&#xff09;都对应有一个独立…

Java经典笔试题—day13

Java经典笔试题—day13 &#x1f50e;选择题&#x1f50e;编程题&#x1f36d;参数解析&#x1f36d;跳石板 &#x1f50e;结尾 &#x1f50e;选择题 (1)一个关系数据库文件中的各条记录 &#xff08;&#xff09; A. 前后顺序不能任意颠倒&#xff0c;一定要按照输入的顺序排…

测试4-数据库设计

测试4-数据库设计 目录 测试4-数据库设计选择题简答题1. 画E-R图并将其转换为适当的关系模型题目E-R图关系模型 2. 画E-R图并将其转换为关系模型题目E-R图关系模型 选择题 下列关于数据库运行和维护的叙述中&#xff0c;正确的是D。 A &#xff0e;只要数据库正式投入运行&…