MyBatis操作数据库(入门)
一.MyBatis的简单介绍
MyBatis(原名iBatis)是一款优秀的持久层框架,它支持定制化SQL、存储过程以及高级映射。
中文网文档:MyBatis中文网
二.MyBatis的使用
1.配置文件data:image/s3,"s3://crabby-images/50570/5057078afe14ef60b27fe8f9f6cb1dd662bec33d" alt=""
2.代码
三.测试类
1.Before,After注解
一个测试类
两个测试类
四.MyBatis基础操作
1.打印日志
首先配置yml文件,也可以配置properties文件,这里使用yml文件:
添加打印日志前:
添加打印日志后:
2.查询的参数传递
传递一个参数的写法:
再写到测试类中:
传递多个参数第一种写法:
第二种写法:data:image/s3,"s3://crabby-images/decf1/decf1212f6bec0b53b75963f36c84e97c09d0f38" alt=""
data:image/s3,"s3://crabby-images/82a0e/82a0e332b95953ea872d92d948ea53ce1ab6f72f" alt=""
第三种写法:
3.插入的传递对象
第一种写法:
MyBatis会直接拆分对象里面的字段来进行匹配
第二种写法:
添加了Param注解后,它被默认为只传一个参数,字段信息需要手动通过 . 来进行传递。
获得自增Id
4.删除
5.修改
通过对象修改:data:image/s3,"s3://crabby-images/8e62b/8e62b05c96dc85d547ae23ec1d7f3c228b4002ff" alt=""
data:image/s3,"s3://crabby-images/d3790/d3790e205e16b06c69853da3f208447549736072" alt=""
data:image/s3,"s3://crabby-images/4e30a/4e30a4992401d94d2d58be7aeeeee4742aa24645" alt=""
data:image/s3,"s3://crabby-images/c6b40/c6b406395b5c4a92803fa387c28a20d0caaccf70" alt=""
五.数据库字段和Java字段不同的写法转换
1.通过as进行转换
2.Results注解
3.ResultMap
复用Results注解里面的信息:
4.配置方式
六.MyBatis XML配置文件
1.yml的配置文件:data:image/s3,"s3://crabby-images/c9c3b/c9c3b4d0d71c1d8c260ed8edaa9821f2eee39e55" alt=""
2.xml文件配置
红线圈的部分,是根据你定义的接口路径来选择的。
3.查询信息
(1).xml配置data:image/s3,"s3://crabby-images/05ddf/05ddf2b25cc9c857c201c2df273f1ee024ceb7b0" alt=""
(2).方法data:image/s3,"s3://crabby-images/2c15e/2c15e68d95caac82b3e5ec0d491161b9242e816d" alt=""
data:image/s3,"s3://crabby-images/190ce/190ce9d9316688a4d9c564a17e272af826cd9f20" alt=""
data:image/s3,"s3://crabby-images/07831/07831c9eef329aac1443faf95a955d22b8e37d1e" alt=""
(3).数据库和Java字段不同的处理方式:
(i) 通过as
(ii)使用xmldata:image/s3,"s3://crabby-images/3dcd8/3dcd802ffab4e5ef101841488fa4778a8927b9b8" alt=""
data:image/s3,"s3://crabby-images/efee2/efee2d04228491af0b4423866a5ba601f7103a95" alt=""
(iii)配置data:image/s3,"s3://crabby-images/74d7b/74d7b31034d6a3fe7b39706b15d30b908920f510" alt=""
4.插入信息
(1)xml配置data:image/s3,"s3://crabby-images/b7f87/b7f87b753f796848267d1469aa87e8b73cc394f2" alt=""
(2)Insert实现data:image/s3,"s3://crabby-images/74afe/74afefec286905f8fa00d50482fbfe2575dfccce" alt=""
data:image/s3,"s3://crabby-images/989f5/989f5df4bacf4385530c75cc7bc482f614a58127" alt=""
data:image/s3,"s3://crabby-images/02ec5/02ec59103f68f2a82759ff3f23e8ac19500012b0" alt=""
当使用Param注解时,需要通过 . 来进行字段的分配:
(3)自增id
5.修改
1.需要注意别写错。
6.删除data:image/s3,"s3://crabby-images/0f72c/0f72c653359adc034a6aa1a4adc8dd6efb4d1130" alt=""
data:image/s3,"s3://crabby-images/54470/544709677f60697ae134f1219f96bf451844cec1" alt=""
data:image/s3,"s3://crabby-images/8c3b8/8c3b8d23e124621ad6101fee884486988b19b8e3" alt=""
七.多表查询
1.多表查询的准备:data:image/s3,"s3://crabby-images/2c4b5/2c4b562090e5996addf651a8c4b91d3310d52a52" alt=""
2.使用时需要注意字符串拼接时,末尾加空格:data:image/s3,"s3://crabby-images/e3b9e/e3b9e377cd531ba9d780e44d4f77ec7fd6fa959f" alt=""
data:image/s3,"s3://crabby-images/dc694/dc694e3bd1de11968dd73866d45fade848eb5f0d" alt=""
八.#和$差别
1.#为预编译SQLdata:image/s3,"s3://crabby-images/d5d64/d5d64d7370da4bc0227d4388c8a3dc040be3eddc" alt=""
2.$为即使SQLdata:image/s3,"s3://crabby-images/b7c9b/b7c9b3af8c21d7fd68dd3211e48fce3d1893bb2f" alt=""
3.$的注意事项
(1) 当使用$传递字符串的时候,需要加入引号,不然属于BadSQL语句:
所以使用$传递字符串时,需要加''号进行传递:
4.#和$最大的差别在于$会被SQL注入:
(1)$被注入攻击的SQL' or 1='1:data:image/s3,"s3://crabby-images/90eb5/90eb5da5f65658dfbf1949d285d96dfe25691880" alt=""
(2)#被注入攻击的SQL' or 1='1:data:image/s3,"s3://crabby-images/0cee6/0cee650f30e65aea217e3a209f1cf7fff24574a7" alt=""
data:image/s3,"s3://crabby-images/09e6b/09e6b600b18376f706143240d5fe8853df8ffe1e" alt=""
(3)排序只能用$因为#会自动给字符串增加引号
但是需要注意SQL的注入问题,这里可以使用枚举或者校验参数的方式来防止SQL的注入攻击。
data:image/s3,"s3://crabby-images/7d4c2/7d4c2eb00eeb4cb2c7369befb1c25b91791809cd" alt=""
(4)like模糊查询
如果like模糊查询会引起SQL注入,就没办法继续使用like,可以使用拼接。
(5)拼接data:image/s3,"s3://crabby-images/6df75/6df753fb7ce009d1a0a62d5b1a4acc101a8a5cc2" alt=""
data:image/s3,"s3://crabby-images/24cbb/24cbbfd013ca410b4e1a7642dc2d9690c6cf2c2e" alt=""
九.数据库连接池
1.介绍
数据库连接池负责分配、管理和释放数据库连接,它允许应⽤程序重复使⽤⼀个现有的数据库连接,⽽不是再重新建⽴⼀个.
常⻅的数据库连接池:
• C3P0
• DBCP
• Druid
• Hikari