一、电脑商城项目:

项目功能:登录,注册,热销商品,用户管理(密码,个人信息,头像,收货地址)、购物车(展示、增加、删除)、订单模块。

二、开发顺序:

注册、登录、用户管理、购物车、商品、订单模块

三、某一个模块的开发:

持久层开发:依据前端页面的设置规划相关的SQL语句,以及进行配置

业务层开发:核心功能控制、业务操作以及异常的处理

控制层开发:接受请求、处理响应

前端开发:JS、jQuery、AJAX连接后台

四、项目搭建步骤:

1.IDEA新建项目,导入jar包

2.配置信息

3.创建数据库

4.测试连接:

启动Springboot主类,是否有对应的Spring图形输出

在单元测试类中测试数据库的连接是否可以正常的加载

5.访问项目的静态资源是否可以正常加载,所有的静态资源放到static目录下

五、注册功能-持久层

1.建表如图所示

2.创建用户的实体类

①.通过表的结构可以提取出表的公共字段,放在一个实体类的基类中,起名叫BaseEntity基类中。

②.创建用户的实体类

六、注册-持久层

通过Mybatis来操作数据库。在做Mybatis开发的流程

6.1规划需要执行的SQL语句

1.用户的注册功能,相当于在做数据的插入操作。

INSERT INTO t_user (username,password) VALUES (值列表)

6.2设计接口和抽象方法

6.2.1定义Mapper接口。在项目的目录结构下创建一个mapper包,在这个包下再根据不同的功能模块来创建mapper接口。创建一个Usermapper的接口。要在接口中定义这两个SQL语句的抽象方法。

package com.example.store.mapper;
import com.example.store.entity.User;
/** 处理用户数据操作的持久层接口 */ public interface UserMapper {
/**
* 插入用户数据
* @param user 用户数据
* @return 受影响的行数(增删改都受影响的行数作为返回值,可以根据返回值来判断是否执行成功
*/
Integer insert(User user);
/**
* 根据用户名查询用户数据
* @param username 用户名
* @return 如果找到对应的用户则返回该用户的数据,如果没找到则返回null
*/
User findByUsername(String username);
}

6.2.2在启动类配置mapper接口文件的位置

6.3编写映射

6.3.1定义xml映射文件,与对应的接口进行关联。所有的映射文件都要放置在resources目录下,在这个目录下创建一个mapper文件夹,然后在这个文件夹下存放mapper的映射文件。

6.3.2创建接口对应的映射文件,遵循和接口的名称保持一致即可。创建一个UserMapper.xml文件。

<?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="org.mybatis.example.BlogMapper">
<select id="selectBlog" resultType="Blog">
select * from Blog where id = #{id}
</select>
</mapper>

6.3.3配置接口中的方法对应上SQL语句。需要借助标签来完成——insert\update\delete\select,对应的是SQL语句的增删改查操作。

  <!--自定义映射规则:resultMap标签来完成映射规则的定义-->
<!--id属性:标签给这个映射负责分配一个唯一的id值,对应的就是resultMap=“id属性的值”属性的取值
type属性:取值是一个类,表示的是数据库中查询结果与JAVA中哪个实体类进行结果集的映射
-->
<resultMap id="UserEntityMap" type="com.example.store.entity.User">
<!--将表的资源和类的属性不一致的字段进行匹配指定,名字一致的字段可以省略不写-->
<!--
配合完成名称不一致的映射:
column属性:表示表中的资源名称
property属性:表示类中的属性名称
-->
<!--在定义映射规则时,主键是不可以省略的-->
<id column="uid" property="uid"/>
<result column="is_delete" property="isDelete"/>
<result column="created_user" property="createdUser"/>
<result column="created_time" property="createdTime"/>
<result column="modified_user" property="modifiedUser"/>
<result column="modified_time" property="modifiedTime"/>
</resultMap>
<!--id属性:表示映射的接口方法中的名称,直接在标签的内容部分来编写SQL语句-->
<!--
useGeneratedKeys属性:表示开启某个字段的值自增(主键设置为自增)
keyProperty属性:标签将表中的哪个字段作为主键进行递增
-->
<insert id="insert" useGeneratedKeys="true" keyProperty="uid">
INSERT INTO t_user (
username, password, salt, phone, email, gender, avatar, is_delete,
created_user, created_time, modified_user, modified_time)
VALUES
(#{username}, #{password}, #{salt}, #{phone}, #{email}, #{gender}, #{avatar},
#{isDelete}, #{createdUser}, #{createdTime}, #{modifiedUser}, #{modifiedTime})
</insert> <!-- select语句在执行的时候,查询的结果是一个对象,多个对象-->
<!--
resultType:表示查询的结果集类型,只需要指定对应映射类的类型,并且包含完整包接口:resultType="com.example.store.entity.User
resultMap: 标签当表的资源和类的对象属性的字段名称不一致时,来自定义查询结果集的映射规则
-->
<select id="findByUsername" resultMap="UserEntityMap">
SELECT
*
FROM
t_user
WHERE
username = #{username}
</select>

配置连接。
在 第一次使用 的时候,除了要配置连接,还要配置相应的驱动,否则连接的时候会报错!!!
图中的①②③④⑤分别表示为:
①、连接的名称
②、连接的数据库地址和端口号(连接本地的数据库就默认为localhost,端口号为3306)
③、MySQL数据库的用户名和密码
④、需要连接的数据库名称
⑤、配置完成之后,点击测试连接,查看是否连接成功。

如图连接成功后,就将IDEA和数据库连接成功了。

6.3.4将mapper文件的位置注册到properties对应的配置文件中。

mybatis.mapper-locations=classpath:mapper/*.xml

6.3.5单元测试:

每个独立的层编写完成后需要编写单元测试方法,来测试当前的功能。在test包结构下创建一个mapper包,在这个包下再创建持久层的测试。

Springboot项目记录1配置环境的更多相关文章

  1. SpringBoot01 InteliJ IDEA安装、Maven配置、创建SpringBoot项目、属性配置、多环境配置

    1 InteliJ IDEA 安装 下载地址:点击前往 注意:需要下载专业版本的,注册码在网上随便搜一个就行啦 2 MAVEN工具的安装 2.1 获取安装包 下载地址:点击前往 2.2 安装过程 到官 ...

  2. SpringBoot项目取消数据库配置

    1. 错误springboot项目启动时,如果没有配置数据库配置,启动时会抛出如下异常. Description: Cannot determine embedded database driver ...

  3. SpringBoot:使用Jenkins自动部署SpringBoot项目(一)环境准备

    1.安装JDK 1.在java官网下载linux下的安装包,上传到云服务器 /user/java 目录下 2.解压:tar xzvf jdk-8u161-linux-x64.tar.gz 3.为了好看 ...

  4. 从源码研究如何不重启Springboot项目实现redis配置动态切换

    上一篇Websocket的续篇暂时还没有动手写,这篇算是插播吧.今天讲讲不重启项目动态切换redis服务. 背景 多个项目或微服务场景下,各个项目都需要配置redis数据源.但是,每当运维搞事时(修改 ...

  5. springboot项目根据不同的环境启动不同的配置,如开发环境dev,测试环境sit,生产环境application

    在项目开发中,会有多个环境,如在开发环境开发完,然后在测试环境测试,最后到生产环境,每个环境的配置是不一样的,如数据库配置:还好spring提供了一个管理配置的方式:

  6. idea配置springboot项目记录

    配置文件application.properties server.port=80 server.servlet.context-path=/bookManage spring.mvc.static- ...

  7. Vue+SpringBoot项目实战(一) 搭建环境

    GitHub 地址: https://github.com/dongfanger/sprint-backend https://github.com/dongfanger/sprint-fronten ...

  8. Jenkins + Docker + dockerfile-maven-plugin + Harbor CI/CD spring-boot项目的最轻量级配置

    说明 本文只为方便日后查阅,记录一些关键性的步骤和踩坑的情况. dockerfile-maven-plugin构建镜像配置 <plugin> <groupId>com.spot ...

  9. (入门SpringBoot)SpringBoot项目创建基本配置(二)

    SpringBoot的环境搭建和基本开发:1.环境开发就不说了,一个程序员的基本功:2.基本开发-使用自定义的配置:2.1.配置文件.properties和yml文件.2.2.SpringBoot配置 ...

  10. maven打包springboot项目的插件配置概览

    jar包的术语背景: normal jar: 普通的jar,用于项目依赖引入,不能通过java -jar xx.jar执行,一般不包含其它依赖的jar包. fat jar: 也叫做uber jar,是 ...

随机推荐

  1. k8s心得

    k8s的 Service 记录了发布后服务的基本信息,如 ip,端口

  2. centons7.2 双网口聚合功能配置和验证

    1.启动网络管理器运行systemctl restart NetworkManager2.创建主备绑定连接 nmcli connection add con-name bond0 type bond ...

  3. TP5--路由

    路由定义采用\think\Route类,通常是在应用的路由配置文件application/route.php进行注册 use think\Route; //路由规则 // Route::rule('/ ...

  4. 吴恩达老师机器学习课程chapter07——聚类

    吴恩达老师机器学习课程chapter07--聚类 本文是非计算机专业新手的自学笔记,高手勿喷. 本文仅作速查备忘之用,对应吴恩达(AndrewNg)老师的机器学期课程第十三章. 缺少重要推演,只能作为 ...

  5. 冷冻法快速还原Oracle数据库

    1.重新装完系统之后,把D:\app\Administrator\oradata拷贝出来,app目录. 2.安装Oracle数据库,创建一个和oradata目录内同名的实例. 3.通过停止服务的方式关 ...

  6. svn提交注释限制

    找到svn仓库 目录结构长这样 在hooks下的新建一个名字为pre-commit.bat的可执行文件 注意:findstr后边的.通配符表示一个任意字符,findstr "." ...

  7. OSP6部署流程

    准备4台虚拟机,完成初始化 一.架构如下: Controller  控制节点 也可以复用为计算节点   192.168.6.11 Compute01   192.168.6.21 Compute02  ...

  8. Web Uploader上传文件

    Web Uploader是百度提供的. 1:下载:http://fex.baidu.com/webuploader/(官方下载/示例) 2:使用Web Uploader文件上传需要引入三种资源:JS, ...

  9. 2022-3-11内部群每日三题-清辉PMP

    1.供应商通知项目经理可能延迟交付一个模块.项目经理应该怎么做? A.立即通知相关方. B.通过增加额外的天数来修改项目管理计划,并记录它们对项目时间的影响. C.审查风险管理计划以评估风险,然后通知 ...

  10. C# 使用CefSharp完成自动签到

    1首先新建项目,右键项目选择管理NuGet 程序包,在浏览中搜索CefSharp.Winfrom ,点击安装,会自动安装相应的包.因为CefSharp是不能以AnyCPU的模式运行所以需要修改配置,有 ...