SpringBoot整合Mybatis+druid快速開發(fā)

結(jié)構(gòu)信息.png

1. 配置類

配置類:

@Slf4j
@Configuration
public class DBConfig {

    @Value("${mysql.mapperLocations}")
    private String mapperLocations;

    @Value("${mysql.configLocation}")
    private String configLocation;

    /**
     * 數(shù)據(jù)源
     */
    @Bean("mysqlDataSource")
    @ConfigurationProperties(prefix = "mysql.datasource")
    public DataSource dataSource() {
        return new DruidDataSource();
    }

    @Bean(name = "mysqlSessionFactory")
    public SqlSessionFactory sqlSessionFactorys(@Qualifier("mysqlDataSource") DataSource dataSource) throws Exception {
        try {
            SqlSessionFactoryBean sessionFactoryBean = new SqlSessionFactoryBean();
            //獲取配置文件的dataSource對象
            sessionFactoryBean.setDataSource(dataSource);
            //設(shè)置mybatis-config.xml配置文件位置
            sessionFactoryBean.setConfigLocation(new DefaultResourceLoader().getResource(configLocation));
            //設(shè)置mapper.xml文件所在位置
            Resource[] resources = new PathMatchingResourcePatternResolver().getResources(mapperLocations);
            sessionFactoryBean.setMapperLocations(resources);
            return sessionFactoryBean.getObject();
        } catch (IOException e) {
            log.error("mybatis解析 mapper*xml 失敗", e);
            return null;
        } catch (Exception e) {
            log.error("mybatis sqlSessionFactoryBean創(chuàng)建失敗", e);
            return null;
        }
    }

    /**
     * 操作事務(wù)的Template
     * 此處傳入的dataSource是mysqlDataSource的bean悬而。
     */
    @Bean(name = "mysqlSessionTemplate")
    public SqlSessionTemplate sqlSessionTemplate(
            @Qualifier("mysqlSessionFactory") SqlSessionFactory sqlSessionFactory) {
        return new SqlSessionTemplate(sqlSessionFactory);
    }

 
    @Bean(name = "mysqlTransactionManager")
    public PlatformTransactionManager xxxTransactionManager(@Qualifier("mysqlDataSource") DataSource dataSource) {
        return new DataSourceTransactionManager(dataSource);
    }
}

yml配置:

mysql:
  mapperLocations: classpath:mybatis/mapper/*.xml
  configLocation: classpath:/mybatis/mybatis-config.xml
  datasource:
    name: mysql_test
    url: jdbc:mysql://localhost:3306/test
    username: root
    password: root
    driver-class-name: com.mysql.jdbc.Driver
    minIdle: 5
    maxActive: 100
    initialSize: 10
    maxWait: 60000

啟動類:

@MapperScan("com.tellme.mapper")  //指定掃描的mapper包的位置
@SpringBootApplication
public class TestApplication {

    public static void main(String[] args) {
        SpringApplication.run(TestApplication.class, args);
    }
}

2.插件類

mybatis/mybatis-config.xml配置:

<?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>
    <settings>
        <setting name="cacheEnabled" value="true" />
        <setting name="lazyLoadingEnabled" value="true" />
        <setting name="multipleResultSetsEnabled" value="true" />
        <setting name="useColumnLabel" value="true" />
        <setting name="mapUnderscoreToCamelCase" value="true"/>
        <setting name="useGeneratedKeys" value="true" />
        <setting name="defaultExecutorType" value="SIMPLE" />
        <setting name="defaultStatementTimeout" value="25000" />
    </settings>
    <typeAliases>
        <typeAlias alias="Integer" type="java.lang.Integer" />
        <typeAlias alias="Long" type="java.lang.Long" />
        <typeAlias alias="HashMap" type="java.util.HashMap" />
        <typeAlias alias="LinkedHashMap" type="java.util.LinkedHashMap" />
        <typeAlias alias="ArrayList" type="java.util.ArrayList" />
        <typeAlias alias="LinkedList" type="java.util.LinkedList" />
    </typeAliases>
    
    <plugins>
        <plugin interceptor="com.tellme.Intercept.MybatisLogInterceptor"/>
    </plugins>

</configuration>

插件:

@Slf4j
@Intercepts({@Signature(type = Executor.class, method = "update", args = {MappedStatement.class, Object.class}),
        @Signature(type = Executor.class, method = "query", args = {MappedStatement.class, Object.class,
                RowBounds.class, ResultHandler.class})})
public class MybatisLogInterceptor implements Interceptor {
    @Override
    public Object intercept(Invocation invocation) throws Throwable {
        
        return invocation.proceed();
    }

    @Override
    public Object plugin(Object target) {
        return Plugin.wrap(target, this);
    }

    @Override
    public void setProperties(Properties properties) {

    }
}

3. Mapper類

接口類:

public interface UserMapper {

    User queryUserByUserid(Long userid);

    List<User> queryByName(String name);

    void insertUser(User user);

    void updateUser(User user);

    List<User> queryUserOrder(UserOrder userOrder);

    /**
     * 不存在sql注入的風(fēng)險
     */
    List<User> queryUserOrderNoRisk(UserOrder userOrder);

}

xml類:mybatis/mapper/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="com.tellme.mapper.UserMapper">
    <sql id="column">
        id
        ,`name`,age
    </sql>
    <!--order by 存在sql注入的風(fēng)險W吵亍a濉半沽!-->
    <select id="queryUserOrder" parameterType="com.tellme.po.UserOrder"
            resultType="com.tellme.po.User">
        select *
        from t_user
        order by ${orderByColumn} ${orderType}
    </select>
    <!--order by 不存在sql注入-->
    <select id="queryUserOrderNoRisk" parameterType="com.tellme.po.UserOrder"
            resultType="com.tellme.po.User">
        select * from t_user
        <if test="orderByColumn!=null and orderByColumn=='age'.toString()">
            order by ${orderByColumn}
        </if>
        <if test="orderType!=null and orderType=='asc'.toString()">
            asc
        </if>
        <if test="orderType!=null and orderType=='desc'.toString()">
            desc
        </if>
    </select>

    <select id="queryUserByUserid" parameterType="java.lang.Long"
            resultType="com.tellme.po.User">
        select
        <include refid="column"></include>
        from t_user
        where id = #{userid}
    </select>
    <!--結(jié)果集是List,但是resultType依舊是單個元素-->
    <select id="queryByName" parameterType="java.lang.String"
            resultType="com.tellme.po.User">
        select
        <include refid="column"></include>
        from t_user
        where name = #{name}
    </select>


    <insert id="insertUser" parameterType="com.tellme.po.User">
        INSERT INTO t_user (name, age) value (#{name},#{age})
    </insert>

    <update id="updateUser" parameterType="com.tellme.po.User">
        UPDATE t_user
        SET name=#{name},
            age=#{age}
        WHERE id = #{id}
    </update>

</mapper>

詳見:mybatis如何預(yù)防不經(jīng)意間的SQL注入

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末到忽,一起剝皮案震驚了整個濱河市橄教,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌喘漏,老刑警劉巖护蝶,帶你破解...
    沈念sama閱讀 206,839評論 6 482
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異翩迈,居然都是意外死亡持灰,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,543評論 2 382
  • 文/潘曉璐 我一進(jìn)店門负饲,熙熙樓的掌柜王于貴愁眉苦臉地迎上來堤魁,“玉大人喂链,你說我怎么就攤上這事∫涛校” “怎么了?”我有些...
    開封第一講書人閱讀 153,116評論 0 344
  • 文/不壞的土叔 我叫張陵吧慢,是天一觀的道長涛漂。 經(jīng)常有香客問我,道長检诗,這世上最難降的妖魔是什么匈仗? 我笑而不...
    開封第一講書人閱讀 55,371評論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮逢慌,結(jié)果婚禮上悠轩,老公的妹妹穿的比我還像新娘。我一直安慰自己攻泼,他們只是感情好火架,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,384評論 5 374
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著忙菠,像睡著了一般何鸡。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上牛欢,一...
    開封第一講書人閱讀 49,111評論 1 285
  • 那天骡男,我揣著相機(jī)與錄音,去河邊找鬼傍睹。 笑死隔盛,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的拾稳。 我是一名探鬼主播吮炕,決...
    沈念sama閱讀 38,416評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼访得!你這毒婦竟也來了来屠?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,053評論 0 259
  • 序言:老撾萬榮一對情侶失蹤震鹉,失蹤者是張志新(化名)和其女友劉穎俱笛,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體传趾,經(jīng)...
    沈念sama閱讀 43,558評論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡迎膜,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,007評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了浆兰。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片磕仅。...
    茶點(diǎn)故事閱讀 38,117評論 1 334
  • 序言:一個原本活蹦亂跳的男人離奇死亡珊豹,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出榕订,到底是詐尸還是另有隱情店茶,我是刑警寧澤,帶...
    沈念sama閱讀 33,756評論 4 324
  • 正文 年R本政府宣布劫恒,位于F島的核電站贩幻,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏两嘴。R本人自食惡果不足惜丛楚,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,324評論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望憔辫。 院中可真熱鬧趣些,春花似錦、人聲如沸贰您。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,315評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽锦亦。三九已至功茴,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間孽亲,已是汗流浹背坎穿。 一陣腳步聲響...
    開封第一講書人閱讀 31,539評論 1 262
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留返劲,地道東北人玲昧。 一個月前我還...
    沈念sama閱讀 45,578評論 2 355
  • 正文 我出身青樓,卻偏偏與公主長得像篮绿,于是被迫代替她去往敵國和親孵延。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,877評論 2 345

推薦閱讀更多精彩內(nèi)容