欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

使用?mybatis?自定義日期類型轉(zhuǎn)換器的示例代碼

 更新時(shí)間:2022年03月09日 16:49:27   作者:Le`soleil  
這篇文章主要介紹了使用?mybatis?自定義日期類型轉(zhuǎn)換器的示例代碼,這里使用mybatis中的typeHandlers?實(shí)現(xiàn)的,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下

前言

使用mybatis中的typeHandlers 實(shí)現(xiàn)自定義日期類型的轉(zhuǎn)換器。
重點(diǎn)在2.2 handler中

一、resources

在這里插入圖片描述

1.1 sqlMapConfig.xml

typeHandlers: 自定義的日期類型轉(zhuǎn)換器:
(1)將日期類型轉(zhuǎn)為long的長(zhǎng)整型存入數(shù)據(jù)庫(kù)中。
(2)將數(shù)據(jù)庫(kù)中的bigint(本質(zhì)對(duì)應(yīng)java的long類型)轉(zhuǎn)為date類型。environments:加載數(shù)據(jù)庫(kù)mapper: 映射文件的位置

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN" "http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>

    <typeHandlers>
        <typeHandler handler="com.mytest.handler.DateTypeHandler"></typeHandler>
    </typeHandlers>
    <environments default="dev">
        <environment id="dev">
            <transactionManager type="JDBC"></transactionManager>
            <dataSource type="POOLED">
                <property name="driver" value="com.mysql.jdbc.Driver"/>
                <property name="url" value="jdbc:mysql://localhost:3306/test"/>
                <property name="username" value="root"/>
                <property name="password" value="123456"/>
            </dataSource>
        </environment>
    </environments>
    <mappers>
        <mapper resource="com.mytest.mapper/UserMapper.xml"></mapper>
    </mappers>
</configuration>

1.2 log4j.properties

打印日志

### direct log messages to stdout ###
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.Target=System.out
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%d{ABSOLUTE} %5p %c{1}:%L - %m%n

### direct messages to file mylog.log ###
log4j.appender.file=org.apache.log4j.FileAppender
log4j.appender.file.File=c:/mylog.log
log4j.appender.file.layout=org.apache.log4j.PatternLayout
log4j.appender.file.layout.ConversionPattern=%d{ABSOLUTE} %5p %c{1}:%L - %m%n
### set log levels - for more verbose logging change 'info' to 'debug' ###
log4j.rootLogger=debug, stdout

1.3 userMapper.xml

1.findByid: 通過(guò)id查詢插入元素

2.save: xml映射器mapper時(shí),

useGeneratedKeys:值為true 并分別指定屬性:
keyProperty: 對(duì)應(yīng)的Java對(duì)象的主鍵屬性
keyColumn: 對(duì)應(yīng)的數(shù)據(jù)庫(kù)記錄主鍵字段

<?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.mytest.dao.UserMapper">
<!--    通過(guò)id查詢插入元素-->

    <select id="findByid" parameterType="int" resultType="com.mytest.pojo.User">
        select * from sys_user where id=#{id}
    </select>

<!--    插入元素-->
    <insert id="save" parameterType="com.mytest.pojo.User" useGeneratedKeys="true" keyProperty="id" keyColumn="id">
        insert into sys_user(id,username,email,password,phoneNum,birthday) values(null,#{username},null,#{password},null,#{birthday})
    </insert>
</mapper>

二、java結(jié)構(gòu)

在這里插入圖片描述

2.1 dao

UserMapper

1.findByid: 使用id值查詢User

2.save: 插入U(xiǎn)ser到數(shù)據(jù)庫(kù)中

package com.mytest.dao;

import com.mytest.pojo.User;
import java.util.List;
public interface UserMapper {
    
    User findByid(int id);
    public void save(User user);
}

2.2 handler

DateTypeHandler

  1. setNonNullParameter:將java類型 轉(zhuǎn)換成 數(shù)據(jù)庫(kù)需要的類型
  2. getNullableResult:將數(shù)據(jù)庫(kù)中類型 轉(zhuǎn)換成java類型
package com.mytest.handler;

import org.apache.ibatis.type.BaseTypeHandler;
import org.apache.ibatis.type.JdbcType;
import java.sql.CallableStatement;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.Date;
public class DateTypeHandler extends BaseTypeHandler<Date> {
    //將java類型 轉(zhuǎn)換成 數(shù)據(jù)庫(kù)需要的類型
    public void setNonNullParameter(PreparedStatement preparedStatement, int i, Date date, JdbcType jdbcType) throws SQLException {
        long time = date.getTime();
        preparedStatement.setLong(i,time);
    }
    //將數(shù)據(jù)庫(kù)中類型 轉(zhuǎn)換成java類型
    //String參數(shù)  要轉(zhuǎn)換的字段名稱
    //ResultSet 查詢出的結(jié)果集
    public Date getNullableResult(ResultSet resultSet, String s) throws SQLException {
        //獲得結(jié)果集中需要的數(shù)據(jù)(long) 轉(zhuǎn)換成Date類型 返回
        long aLong = resultSet.getLong(s);
        Date date = new Date(aLong);
        return date;
    public Date getNullableResult(ResultSet resultSet, int i) throws SQLException {
        long aLong = resultSet.getLong(i);
    public Date getNullableResult(CallableStatement callableStatement, int i) throws SQLException {
        long aLong = callableStatement.getLong(i);
}

2.3 pojo

package com.mytest.pojo;

import java.util.Date;
public class User {
    private Integer id;
    private String username;
    private String password;
    private Date birthday;
    public Date getBirthday() {
        return birthday;
    }
    public void setBirthday(Date birthday) {
        this.birthday = birthday;
    @Override
    public String toString() {
        return "User{" +
                "id=" + id +
                ", username='" + username + '\'' +
                ", password='" + password + '\'' +
                ", birthday=" + birthday +
                '}';
    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;
}

2.4 service

service沒(méi)用進(jìn)行實(shí)現(xiàn),在本demo中只用于測(cè)試使用。
sqlSession.commit()用于mybatis的事務(wù)提交。mybatis的事務(wù)默認(rèn)是不提交的,故在增刪改中需要進(jìn)行事務(wù)的提交,在mybatis中事務(wù)的提交方式一般有兩種:
1 sqlSession.commit()
2 采用openSession(true),即可實(shí)現(xiàn)自動(dòng)提交,無(wú)需調(diào)用commit()方法。

package com.mytest.service;

import com.mytest.dao.UserMapper;
import com.mytest.pojo.User;
import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
import java.io.IOException;
import java.io.InputStream;
import java.util.Date;
import java.util.List;
public class ServiceTest {
    public static void main(String[] args) throws IOException {
        InputStream inputStream = Resources.getResourceAsStream("sqlMapConfig.xml");
        SqlSessionFactory sqlSessionFactory = (SqlSessionFactory) new SqlSessionFactoryBuilder().build(inputStream);
        //openSession為true則自動(dòng)提交事務(wù)
        SqlSession sqlSession = sqlSessionFactory.openSession();
        UserMapper mapper = sqlSession.getMapper(UserMapper.class);
        User user = new User();
        //插入不需要設(shè)置id值
//        user.setId(5);
        user.setUsername("wangwu");
        user.setPassword("123");
        user.setBirthday(new Date());
        //會(huì)返回屬性值
        mapper.save(user);
        Integer userId = user.getId();
        
        sqlSession.commit();
        User findUser = mapper.findByid(userId);
        System.out.println(findUser);
    }
}

三 數(shù)據(jù)表結(jié)構(gòu)及測(cè)試

數(shù)據(jù)表結(jié)構(gòu)

在這里插入圖片描述

測(cè)試

在這里插入圖片描述

到此這篇關(guān)于使用 mybatis 自定義日期類型轉(zhuǎn)換器的文章就介紹到這了,更多相關(guān)mybatis 自定義日期類型轉(zhuǎn)換器內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • SpringBoot中@ConditionalOnBean實(shí)現(xiàn)原理解讀

    SpringBoot中@ConditionalOnBean實(shí)現(xiàn)原理解讀

    這篇文章主要介紹了SpringBoot中@ConditionalOnBean實(shí)現(xiàn)原理,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-02-02
  • Java監(jiān)聽(tīng)器的作用及用法代碼示例

    Java監(jiān)聽(tīng)器的作用及用法代碼示例

    這篇文章主要介紹了Java監(jiān)聽(tīng)器的作用及用法代碼示例,具有一定參考價(jià)值,需要的朋友可以了解下。
    2017-11-11
  • SpringBoot實(shí)現(xiàn)excel文件生成和下載

    SpringBoot實(shí)現(xiàn)excel文件生成和下載

    這篇文章主要為大家詳細(xì)介紹了SpringBoot實(shí)現(xiàn)excel文件生成和下載,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-02-02
  • java繪制哆啦A夢(mèng) 超可愛(ài)

    java繪制哆啦A夢(mèng) 超可愛(ài)

    這篇文章主要介紹了java繪制哆啦A夢(mèng),特別的可愛(ài),文中示例代碼介紹的也非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-05-05
  • SpringBoot進(jìn)行參數(shù)校驗(yàn)的方法詳解

    SpringBoot進(jìn)行參數(shù)校驗(yàn)的方法詳解

    在日常的接口開(kāi)發(fā)中,為了防止非法參數(shù)對(duì)業(yè)務(wù)造成影響,經(jīng)常需要對(duì)接口的參數(shù)進(jìn)行校驗(yàn)。本文通過(guò)示例詳細(xì)講解了SpringBoot如何進(jìn)行參數(shù)校驗(yàn)的,感興趣的可以學(xué)習(xí)一下
    2022-04-04
  • SpringBoot+隨機(jī)鹽值+雙重MD5實(shí)現(xiàn)加密登錄

    SpringBoot+隨機(jī)鹽值+雙重MD5實(shí)現(xiàn)加密登錄

    數(shù)據(jù)加密在很多項(xiàng)目上都可以用到,大部分都會(huì)采用MD5進(jìn)行加密,本文主要介紹了SpringBoot+隨機(jī)鹽值+雙重MD5實(shí)現(xiàn)加密登錄,具有一定的參考價(jià)值,感興趣的可以了解一下
    2024-02-02
  • 基于SpringBoot集成測(cè)試遠(yuǎn)程連接Redis服務(wù)的教程詳解

    基于SpringBoot集成測(cè)試遠(yuǎn)程連接Redis服務(wù)的教程詳解

    這篇文章主要介紹了基于SpringBoot集成測(cè)試遠(yuǎn)程連接的Redis服務(wù)的相關(guān)知識(shí),本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-03-03
  • springboot時(shí)間格式化的五種方法總結(jié)(解決后端傳給前端的時(shí)間顯示不一致)

    springboot時(shí)間格式化的五種方法總結(jié)(解決后端傳給前端的時(shí)間顯示不一致)

    這篇文章主要給大家介紹了關(guān)于springboot時(shí)間格式化的五種方法,文中介紹的方法解決了后端傳給前端的時(shí)間顯示不一致,文中通過(guò)圖文以及代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2024-01-01
  • Java方法簽名的獲取實(shí)例代碼

    Java方法簽名的獲取實(shí)例代碼

    這篇文章主要介紹了Java方法簽名的獲取實(shí)例代碼,分享了相關(guān)代碼示例,小編覺(jué)得還是挺不錯(cuò)的,具有一定借鑒價(jià)值,需要的朋友可以參考下
    2018-02-02
  • SpringMVC后端返回?cái)?shù)據(jù)到前端代碼示例

    SpringMVC后端返回?cái)?shù)據(jù)到前端代碼示例

    這篇文章主要介紹了SpringMVC后端返回?cái)?shù)據(jù)到前端代碼示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-04-04

最新評(píng)論