Во-вторых, проект интеграции SpringBoot сражается с mybatis

Spring Boot

предисловие

В прошлой статье мы начали наше предисловие к springboot, мы настроили базу данных mysql, но наш оператор sql был написан непосредственно в контроллере и использовался jdbcTemplate. В проекте точно не используется.В прошлой статье тоже было сказано, что будет использоваться в связке с mybatis или JPA. Давайте использовать эту статью в сочетании с mybatis.Что касается того, почему я выбираю mybatis вместо JPA, это зависит от человека. Затем эта статья будет сопровождаться рассказом о новой конфигурации, добавленной сегодня в проект. Главным образом для того, чтобы проекты и статьи были согласованными.

Давайте сначала выложим структуру нашего сегодняшнего проекта, которая аналогична той, что мы выкладывали вчера, на основе добавлены некоторые вещи, и сформирована модель всего фреймворка.file

Внедрение зависимостей mybatis

Как правило, изменения начинаются с pom.xml, мы добавляем зависимость mybatis в файл pom.xml на основе вчерашнего дня и выбираем версию самостоятельно.

<dependency>
    <groupId>org.mybatis.spring.boot</groupId>
    <artifactId>mybatis-spring-boot-starter</artifactId>
    <version>2.0.0</version>
 </dependency>

Входной слой

Вчера мы создали пользовательскую таблицу и вставили часть данных, давайте сначала воспользуемся этой таблицей, поэтому мы создаем класс сущности UserEntry в входном пакете, Код выглядит следующим образом:

@Getter
@Setter
public class UserEntry {
    private int id;
    private String userName;
    private String password;
    private String email;
    private String roleCode;
    private String roleName;
    private String gmtCreate;
    private String gmtUpdate;
    private String nickname;
    private String userCreate;
}

Вы можете увидеть используемые аннотации и @Getter и @Setter здесь. Это сделано для того, чтобы избежать написания слишком большого количества методов get и set в коде, что делает код более кратким.

Слой Дао

Dao используется для обработки данных, здесь мы представляем mybatis, вы можете использовать аннотации, вы также можете создать файл xml и написать оператор sql в файле xml. Давайте воспользуемся здесь методом аннотации, ведь наш проект springboot больше не хочет иметь файл конфигурации xml (может быть, ха-ха позже).

Создайте интерфейс userMapper в пакете dao. код показывает, как показано ниже:


@Mapper
public interface UserMapper {

    @Select("select id,username as userName,password,email,role_code as roleCode,gmt_create as gmtCreate,gmt_update as gmtUpdate,nickname as nickName,user_create as userCreate from sys_user")
    List<UserEntry> findUserList();

    @Insert({"insert into sys_user(username,password,email) values('${user.userName}','${user.password}','${user.email}')"})
    int add(@Param("user") UserEntry user);

    @Delete("delete from sys_user where id = #{id}")
    int delete(int id);

}

Давайте сначала напишем запрос, удалим и вставим сюда метод. Видно, что на интерфейс введена аннотация @Mapper, а затем можно напрямую использовать такие аннотации, как @Select и @Insert, и прямо в нем можно написать аннотированный sql-оператор.

Сервисный уровень

На сервисном уровне мы обычно используем интерфейс и конкретный класс, реализующий интерфейс.

сервисный интерфейс

код показывает, как показано ниже:


public interface UserService {

    List<UserEntry> findUserList();

    int addUser(String userName,String password,String email);

    int deleteUser(int id);
}

Конкретный класс реализации serviceImpl.

Создайте класс UserServiceImpl в пакете impl пакета службы. код показывает, как показано ниже:


@Service
public class UserServiceImpl implements UserService {


    @Autowired
    protected UserMapper userMapper;

    @Override
    public List<UserEntry> findUserList() {
        return userMapper.findUserList();
    }

    @Override
    public int addUser(String userName, String password, String email) {
        UserEntry user=new UserEntry();
        user.setUserName(userName);
        user.setPassword(password);
        user.setEmail(email);
        return userMapper.add(user);
    }

    @Override
    public int deleteUser(int id) {
        return userMapper.delete(id);
    }
}

слой контроллера

Мы создаем класс UserController в пакете userinfo в пакете контроллера. код показывает, как показано ниже:


@Slf4j
@RestController
@RequestMapping("/user")
public class UserController {

    @Autowired
    private UserService userService;

    @RequestMapping(value = "/list",method = RequestMethod.GET)
    public List<UserEntry> findUserList(){
        return userService.findUserList();
    }

    @RequestMapping(value = "/add",method = RequestMethod.GET)
    public String addUser(@RequestParam(value = "userName")String uaserName,@RequestParam(value = "password")String password,@RequestParam(value = "email")String email){
        int falg=userService.addUser(uaserName,password,email);
        if(falg>0){
            return "success";
        }
        return "error";
    }

    @RequestMapping(value = "/delete",method = RequestMethod.GET)
    public String deleteUser(@RequestParam(value = "id")int id){
        if(userService.deleteUser(id)>0){
            return "success";
        }
        return "error";
    }
}

контрольная работа

Что ж, все на месте, давайте тестировать. После запуска проекта вводим в браузере

添加一个用户
http://localhost:9090/zlflovemm/user/add?userName=qaz&password=123456&email=123@qq.com

file

查询所有用户
http://localhost:9090/zlflovemm/user/list

file

删除一个用户
http://localhost:9090/zlflovemm/user/delete?id=19

file

Нет проблем, это означает, что основные добавления, удаления, изменения, проверки и интеграция mybatis возможны.

Настроить несколько файлов среды

Ладно, большой разговор окончен, давайте сегодня поговорим о конфигурации проекта. Во-первых, давайте взглянем еще на несколько файлов конфигурации в нашем проекте.fileСоответствует среде разработки, тестовой среде, производственной среде. Ведь в реальном процессе разработки часто используются эти три окружения, и всегда будут проблемы с изменением соединений с БД. Настройте несколько копий прямо здесь, вы можете использовать все, что захотите. Избегайте повторяющихся ошибок. Здесь я временно разместил ссылку для подключения к mysql в другой среде. Сначала добавьте в application.properties

spring.profiles.active=dev
表示用的是开发环境,就会读取application-dev.yml 文件中的配置。

Содержимое файла application-dev.xml следующее, а два других файла аналогичны, поэтому они не будут опубликованы.file

журнал конфигурации

Как может быть нехватка лог-файлов в проекте?Логбек фреймворка, который идет в комплекте с springboot, который я здесь использую, тоже очень удобен. Сначала мы добавляем в application.properties

#日志配置
logging.level.org.springframework.web=info
logging.config=classpath:logback.xml
debug=true

Затем создайте файл logback.xml в том же каталоге, что и application.properties.Содержимое будет следующим:

<?xml version="1.0" encoding="UTF-8"?>
<configuration debug="false">

    <!--定义日志文件的存储地址 勿在 LogBack 的配置中使用相对路径-->
    <property name="LOG_HOME" value="./logs" />
    <property name="INFO_FILE" value="zlflovemm_log" />
    <property name="ERROR_FILE" value="zlflovemm_error" />

    <!--控制台日志, 控制台输出 -->
    <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
        <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
            <!--格式化输出:%d表示日期,%thread表示线程名,%-5level:级别从左显示5个字符宽度,%msg:日志消息,%n是换行符-->
            <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n</pattern>
        </encoder>
    </appender>

    <!-- 文件保存日志的相关配置,同步 -->
    <appender name="FILE"  class="ch.qos.logback.core.rolling.RollingFileAppender">
        <Prudent>true</Prudent>
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <!--日志文件输出的文件名-->
            <FileNamePattern>
                ${LOG_HOME}/${INFO_FILE}-%d{yyyy-MM-dd}.log
            </FileNamePattern>
            <!--日志文件保留天数-->
            <MaxHistory>30</MaxHistory>
        </rollingPolicy>
        <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
            <!--格式化输出:%d表示日期,%thread表示线程名,%-5level:级别从左显示5个字符宽度%msg:日志消息,%n是换行符-->
            <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS}[%t][%thread] %-5level %logger{36} - %msg%n</pattern>
        </encoder>
        <!--日志文件最大的大小-->
        <triggeringPolicy class="ch.qos.logback.core.rolling.SizeBasedTriggeringPolicy">
            <MaxFileSize>10MB</MaxFileSize>
        </triggeringPolicy>
    </appender>

    <!-- 文件保存日志的相关配置,同步 -->
    <appender name="ERROR"  class="ch.qos.logback.core.rolling.RollingFileAppender">
        <filter class="ch.qos.logback.classic.filter.ThresholdFilter">
            <level>ERROR</level>
        </filter>
        <Prudent>true</Prudent>
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <!--日志文件输出的文件名-->
            <FileNamePattern>
                ${LOG_HOME}/${ERROR_FILE}-%d{yyyy-MM-dd}.log
            </FileNamePattern>
            <!--日志文件保留天数-->
            <MaxHistory>30</MaxHistory>
        </rollingPolicy>
        <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
            <!--格式化输出:%d表示日期,%thread表示线程名,%-5level:级别从左显示5个字符宽度%msg:日志消息,%n是换行符-->
            <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS}[%t][%thread] %-5level %logger{36} - %msg%n</pattern>
        </encoder>
        <!--日志文件最大的大小-->
        <triggeringPolicy class="ch.qos.logback.core.rolling.SizeBasedTriggeringPolicy">
            <MaxFileSize>10MB</MaxFileSize>
        </triggeringPolicy>
    </appender>

    <!-- 日志输出级别 -->
    <root level="INFO">
        <appender-ref ref="STDOUT" />
        <appender-ref ref="FILE"/>
        <appender-ref ref="ERROR" level="error" />
    </root>
</configuration>

Таким образом настраивается журнал проекта.Что касается конкретной конфигурации журнала, вы можете изменить параметры в logback.xml. Аналогично log4g.

Настроить баннер

В конце концов, раз уж это проект, то, конечно же, должно быть что-то знаковое, например, логотип. springboot оставил нам пасхальное яйцо, которое является баннером. Мы можем отобразить наш уникальный логотип при запуске проекта.Создайте файл banner.txt в той же директории, что и application.properties.fileВы можете сами искать художественные слова в Интернете, поэтому я не рекомендую это здесь, ха-ха. Таким образом, мы загрузим наш логотип при запуске проекта, что можно рассматривать как преимущество для большинства из нас.

интермедия

Я наконец закончил писать сегодня вечером, я бы сделал это раньше, но я не знаю, почему так поздно. Код проекта сегодня также синхронизирован с github. адрес гитхаба: https://github.com/QuellanAn/zlflovemm

Следите за новостями ♡

Приглашаем всех обратить внимание на персональный публичный номер "Программисты любят кефир"

Делитесь различными учебными материалами, включая Java, Linux, большие данные и т. д. Материалы включают видеодокументы и исходный код, а также высококачественные технические посты в блогах о себе и о доставке.

Если вам понравилось, не забудьте подписаться и поделиться ❤file