springboot+mybatis实现简单的登录及基于用户和角色表的增删改查

 示例代码已上传 githubicon-default.png?t=N176https://github.com/name-zj/springweb,有兴趣可下载,另附mysql运行脚本icon-default.png?t=N176https://download.csdn.net/download/King_crazy/12438602

效果展示:

1,登录页

2. 主页面

效果就是这样了,下面是代码的结构层级

建立一个Spring Assistant项目,这里ideal使用的是社区版,如果你是用的是专业版,会稍有区别,好像是对应Spring initializr。

项目建完后,就可以开始你的表演了。

以登录的校验为开头讲解。首先,mysql里已经建好了相关表,上面给了运行文件。

1.role

2.user

3.user_role

然后,根据根据建立的数据表,创建实体类,放在com.zj.entity目录下:

1.User

package com.zj.service.entity;

import java.io.Serializable;

public class User implements Serializable {
    private Integer id;
    private String username;
    private String password;
    private Integer isDelete;
    private String roleName;

    public Integer getIsDelete() {
        return isDelete;
    }

    public void setIsDelete(Integer idDelete) {
        this.isDelete = idDelete;
    }

    public Integer getId() {
        return id;
    }

    public void setId(Integer id) {
        this.id = id;
    }

    public String getUsername() {
        return username;
    }

    public void setUsername(String username) {
        this.username = username;
    }

    public String getPassword() {
        return password;
    }

    public void setPassword(String password) {
        this.password = password;
    }

    public String getRoleName() {
        return roleName;
    }

    public void setRoleName(String roleName) {
        this.roleName = roleName;
    }
}

2. Role

package com.zj.service.entity;

import java.io.Serializable;

public class Role implements Serializable {
    private Integer id;
    private String rolename;
    private Integer isRead;
    private Integer isWrite;

    public Integer getId() {
        return id;
    }

    public void setId(Integer id) {
        this.id = id;
    }

    public String getRolename() {
        return rolename;
    }

    public void setRolename(String rolename) {
        this.rolename = rolename;
    }

    public Integer getIsRead() {
        return isRead;
    }

    public void setIsRead(Integer isRead) {
        this.isRead = isRead;
    }

    public Integer getIsWrite() {
        return isWrite;
    }

    public void setIsWrite(Integer isWrite) {
        this.isWrite = isWrite;
    }
}

3.UserRole

package com.zj.service.entity;

import java.io.Serializable;

public class UserRole implements Serializable {
    private Integer id;
    private Integer userId;
    private Integer roleId;

    public Integer getId() {
        return id;
    }

    public void setId(Integer id) {
        this.id = id;
    }

    public Integer getUserId() {
        return userId;
    }

    public void setUserId(Integer userId) {
        this.userId = userId;
    }

    public Integer getRoleId() {
        return roleId;
    }

    public void setRoleId(Integer roleId) {
        this.roleId = roleId;
    }
}

然后,定义要各实体对应的操作的方法。登录,那肯定涉及一个用户的查询,判定用户是否存在,所以先建一个user的mapper,用以数据库操作,放在com.zj.mapper目录下。这里使用mybatis注解的方式实现(有个小的注意点,比如"from user ",换行的话,在uses后边加个空格,要不然会和后面的连在一起变成"from userwhere"),注解实现比较简单,基本一看就会,就是在抽象方法上面写SQL。如果传过来的是User对象,以取username属性为例,则使用#{username}的方式,#{username}的意思是在使用,会调用这个对象实体类中定义的getUsername()方法;如果传的是个变量,比如int id,则直接用#{id}即可

  • 2
    点赞
  • 26
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
# 简介 这个项目是一个简单的教务查询系统,其中有三种角色:管理员,教师,学生。三种角色都有相应的权限,其中: * 管理员:对课程、学生信息、教师信息等进行增删改查,修改个人密码,修改学生和教师的密码 * 教师:可以查看自己教授的课程,查询选修该课程的学生,对选修该课程的学生进行打分,修改个人密码 * 学生:可以进行选课,查看已修课程,查看已选课程,退选课程,修改个人密码 # 使用技术 Web框架SpringBoot ORM框架Mybatis 安全框架:Shiro 分页插件:PageHelper 连接池:SpringBoot自带的HiKariCP 日志:SpringBoot自带的LogBack 前端框架Bootstrap # 在线预览 [http://23188i98c9.51mypc.cn:28070](http://23188i98c9.51mypc.cn:28070) * 登录账户 * 管理员账户:admin * 老师账户:1001 * 学生账户:10001 * 密码均为:123 # 快速上手 ### 1、运行环境和所需工具 * 编译器:IntelliJ IDEA * 项目构建工具:Maven * 数据库:Mysql、Redis * JDK版本:jdk1.8 * Tomcat版本:Tomcat8.x ### 2、初始化项目 * 在你的Mysql中,创建一个数据库名称为 EducationalManagementSystem 的数据库,并导入我提供的 .sql 文件。 * 进入src/main/resources修改application.properties配置文件,把数据库登录名和密码,改为你本地的。 * 使用 IntelliJ IDEA 导入项目,选择Maven项目选项,一路点击next就行。 * 在 IntelliJ IDEA 中,运行SpringBoot启动类。 * 运行 ![login](png/login.png) # 功能模块介绍 ### 1、登录模块功能 使用Shiro权限管理框架实现登录验证和登录信息的储存,根据不同的登录账户,分发权限角色,对不同页面url进行角色设置 ### 2、管理员模块功能 管理员可对课程、学生信息、教师信息等进行增删改查,修改个人密码,修改学生和教师的密码 * 课程管理:当课程已经有学生选课成功时,将不能删除 * 学生管理:添加学生信息时,其信息也会添加到登录中 * 教师管理:添加教师信息时,其信息也会添加到登录中 * 账户密码重置:修改学生和教师的密码,不需要输入旧密码 * 修改密码:修改自己的密码,需要输入旧密码 ## 项目备注 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用! 2、本项目适合计算机相关专业(如计科、人工智能、通信工程、自动化、电子信息等)的在校学生、老师或者企业员工下载学习,也适合小白学习进阶,当然也可作为毕设项目、课程设计、作业、项目初期立项演示等。 3、如果基础还行,也可在此代码基础上进行修改,以实现其他功能,也可用于毕设、课设、作业等。 下载后请首先打开README.md文件(如有),仅供学习参考, 切勿用于商业用途。
### 回答1: Spring BootMyBatis是一种常见的Java Web开发框架,可以用来实现增删改查操作。具体步骤如下: 1. 配置数据库连接信息,包括数据库驱动、数据库URL、用户名和密码等。 2. 创建实体类,用于映射数据库结构。 3. 创建Mapper接口,定义增删改查方法。 4. 创建Mapper.xml文件,编写SQL语句,实现Mapper接口中定义的方法。 5. 创建Service层,调用Mapper接口中的方法,实现业务逻辑。 6. 创建Controller层,接收请求,调用Service层中的方法,返回响应。 7. 配置Spring Boot启动类,启动应用程序。 以上是实现增删改查的基本步骤,具体实现过程需要根据具体业务需求进行调整。 ### 回答2: SpringBoot是一个用于构建基于Spring的应用程序的框架,它是建立在Spring之上的一种轻量级解决方案。MyBatis是一种开源的持久化框架,它是基于Java的持久层框架SpringBootMyBatis可以很好地协作,用于开发各种类型的Web应用程序。在SpringBoot中使用MyBatis实现增删改查操作非常简单,一下是具体操作: 1.数据库配置 首先需要进行数据库配置,可在application.properties(或application.yml)中进行配置,SpringBoot会自动加载这些配置。 spring.datasource.url=jdbc:mysql://localhost:3306/test spring.datasource.username=root spring.datasource.password=123456 spring.datasource.driverClassName=com.mysql.cj.jdbc.Driver 2.依赖配置 pom文件中添加MyBatis和MySQL连接驱动的依赖,如下: <dependency> <groupId>org.mybatis.spring.boot</groupId> <artifactId>mybatis-spring-boot-starter</artifactId> <version>2.1.3</version> </dependency> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>8.0.23</version> </dependency> 3.实体类编写 创建实体类并添加注解@Table(name="名")、@Id等等,如下: @Table(name="userinfo") public class User { @Id private Integer id; private String name; private Integer age; private String address; //省略setter和getter方法 } 4.DAO接口编写 编写DAO接口,如下: public interface UserDao { List<User> getAll(); User getById(Integer id); void insert(User user); void update(User user); void delete(Integer id); } 5.Mapper文件编写 在src/main/resources/mapper下创建Mapper文件,定义SQL语句和方法映射关系,如下: <?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> <mapper namespace="com.example.demo.dao.UserDao"> <resultMap id="userMap" type="com.example.demo.model.User"> <id property="id" column="id"/> <result property="name" column="name"/> <result property="age" column="age"/> <result property="address" column="address"/> </resultMap> <select id="getAll" resultMap="userMap"> SELECT id, name, age, address FROM userinfo </select> <select id="getById" resultMap="userMap"> SELECT id, name, age, address FROM userinfo WHERE id = #{id} </select> <insert id="insert" parameterType="com.example.demo.model.User"> INSERT INTO userinfo(name, age, address) VALUES (#{name}, #{age}, #{address}) </insert> <update id="update" parameterType="com.example.demo.model.User"> UPDATE userinfo SET name = #{name}, age = #{age}, address = #{address} WHERE id = #{id} </update> <delete id="delete" parameterType="int"> DELETE FROM userinfo WHERE id = #{id} </delete> </mapper> 6.DAO接口实现 编写DAO接口实现类UserDaoImpl,代码如下: @Repository public class UserDaoImpl implements UserDao { @Autowired private SqlSessionTemplate sqlSessionTemplate; private final String NAMESPACE = "com.example.demo.dao.UserDao"; @Override public List<User> getAll() { return this.sqlSessionTemplate.selectList(NAMESPACE + ".getAll"); } @Override public User getById(Integer id) { return this.sqlSessionTemplate.selectOne(NAMESPACE + ".getById",id); } @Override public void insert(User user) { this.sqlSessionTemplate.insert(NAMESPACE + ".insert",user); } @Override public void update(User user) { this.sqlSessionTemplate.update(NAMESPACE + ".update",user); } @Override public void delete(Integer id) { this.sqlSessionTemplate.delete(NAMESPACE + ".delete",id); } } 7.Controller层编写 创建Controller层方法,调用DAO层方法,如下: @RestController @RequestMapping("user") public class UserController { @Autowired private UserDao userDao; @GetMapping(value="/getAll") public List<User> getAll() { return userDao.getAll(); } @GetMapping(value="/getById/{id}") public User getById(@PathVariable("id") Integer id) { return userDao.getById(id); } @PostMapping(value="/insert") public void insert(@RequestBody User user) { userDao.insert(user); } @PutMapping(value="/update") public void update(@RequestBody User user) { userDao.update(user); } @DeleteMapping(value="/delete/{id}") public void delete(@PathVariable("id") Integer id) { userDao.delete(id); } } 以上就是利用SpringBootMyBatis完成增删改查操作的详细步骤,可参考实际开发需求进行编写。 ### 回答3: Spring Boot 是一个快速开发框架,它提供了很多默认配置,可以帮助开发者快速地搭建一个项目。MyBatis 是一个持久层框架,可以帮助我们更加方便地操作数据库。Spring BootMyBatis 结合起来使用,可以帮助我们更加方便地实现数据库增删改查操作。 一、环境搭建 首先需要在 pom.xml 文件中引入 Spring BootMyBatis 的依赖。 ``` <!--Spring Boot 依赖--> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> <version>2.4.5</version> </dependency> <!--Mybatis 依赖--> <dependency> <groupId>org.mybatis.spring.boot</groupId> <artifactId>mybatis-spring-boot-starter</artifactId> <version>2.2.0</version> </dependency> ``` 其次,在 application.properties 文件中配置数据源相关信息。 ``` # 数据库配置 spring.datasource.url= jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=UTF-8&serverTimezone=Asia/Shanghai spring.datasource.username=root spring.datasource.password=root spring.datasource.driver-class-name=com.mysql.jdbc.Driver #Mybatis 配置 mybatis.mapper-locations=classpath:mapper/*.xml mybatis.type-aliases-package=com.example.demo.entity ``` 二、创建实体对象和 Mapper 在 Spring Boot 中,我们可以利用注解来快速地完成实体对象和 Mapper 的创建。 1. 创建实体对象 ``` @Data @AllArgsConstructor @NoArgsConstructor public class User { private Integer id; private String name; private Integer age; } ``` 2. 创建 Mapper ``` @Mapper @Component public interface UserMapper { List<User> selectAll(); User selectById(Integer id); int insert(User user); int update(User user); int deleteById(Integer id); } ``` 三、实现增删改查 1. 实现插入操作 ``` @Service public class UserServiceImpl implements UserService { @Autowired private UserMapper userMapper; @Override public boolean insert(User user) { int result = userMapper.insert(user); return result == 1; } } ``` 2. 实现查询操作 ``` @Service public class UserServiceImpl implements UserService { @Autowired private UserMapper userMapper; @Override public List<User> selectAll() { return userMapper.selectAll(); } @Override public User selectById(Integer id) { return userMapper.selectById(id); } } ``` 3. 实现更新操作 ``` @Service public class UserServiceImpl implements UserService { @Autowired private UserMapper userMapper; @Override public boolean update(User user) { int result = userMapper.update(user); return result == 1; } } ``` 4. 实现删除操作 ``` @Service public class UserServiceImpl implements UserService { @Autowired private UserMapper userMapper; @Override public boolean deleteById(Integer id) { int result = userMapper.deleteById(id); return result == 1; } } ``` 以上就是 Spring BootMyBatis 结合,实现数据库增删改查操作的具体步骤。通过使用注解来创建实体对象和 Mapper,能够让我们更加方便地进行数据库操纵。同时,在进行数据库操作时,需要注意事务的处理,避免出现数据异常的情况。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值