1、db.properties

原因:数据库的连接直接写到配置(mybati-config.xml)里存在安全隐患

解决:将配置的信息放到一个文件中管理

右键resources --> File --> 填“db.properties”

db.properties

driver=com.mysql.jdbc.Driver
url=jdbc:mysql://localhost:3306/mybatis?useSSL=true&useUnicode=true&characterEncoding=utf8
username=root
password=123

到配置中进行引入(properties标签)和使用(${}

mybati-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> <!-- 配置标签 -->
<!-- 导入db.properties文件 , 使用 ${} 引入-->
<properties resource="db.properties"/> <environments default="development"> <!-- 总环境 默认:development -->
<environment id="development"> <!-- 环境 名为:development -->
<transactionManager type="JDBC"/> <!-- 事务管理器 类型:JDBC (事务:确保操作完整性,要么成功要么失败)-->
<dataSource type="POOLED"> <!-- 数据源 类型:POOLED-->
<property name="driver" value="${driver}"/> <!--属性 名:驱动 值:..mysql(使用的何种数据库).. -->
<!-- 属性 名:url 值:数据连接地址+规则(如:字符集:UTF-8) -->
<property name="url" value="${url}"/>
<property name="username" value="${username}"/> <!-- 属性 名:数据库用户名 值:root-->
<property name="password" value="${password}"/> <!--属性 名:密码 值:123 -->
</dataSource>
</environment>
</environments>
<mappers> <!--映射器 -->
<mapper resource="com/dao/userMapper.xml"/> <!-- 映射 资源:userMapper.xml -->
</mappers>
</configuration>

2、别名(typeAliases)

原因:为了减少代码的冗余

例如:在userMapping中会常常用到:com.pojo.User,可以进行别名设置。

解决:设置别名,用别名代替全名,减少代码冗余

mybatis-config.xml -->configuration(代码最好放到该标签下的第一位)

    <!--配置别名,注意顺序:最好能放到configuration标签下的第一位。-->
<typeAliases>
<typeAlias type="com.pojo.User" alias="User"/> <!--设置com.pojo.User 别名为:User-->
</typeAliases>

指定包进行别名设置(一般都是使用这个方法)

mybatis-config.xml -->configuration(代码最好放到该标签下的第一位)

<typeAliases>
<package name="com.pojo"/> <!--在该包下所有文件设别名为:文件名-->
</typeAliases>

验证效果:

com/dao/userMapper.xml 为设别名前(com.pojo.User)的代码

<select id="selectUser" resultType="com.pojo.User">

设置了别名后(使用别名:User)的代码,减少了代码冗余

<select id="selectUser" resultType="User">

3、mybatis.config.xml中settings标签

使用settings标签实现

  • 懒加载
  • 日志实现
  • 缓存开启关闭

默认的settings如下,通过修改里面的设置(setting)实现相应的功能。

mybatis-config.xml

<settings>
<setting name="cacheEnabled" value="true"/>
<setting name="lazyLoadingEnabled" value="true"/>
<setting name="multipleResultSetsEnabled" value="true"/>
<setting name="useColumnLabel" value="true"/>
<setting name="useGeneratedKeys" value="false"/>
<setting name="autoMappingBehavior" value="PARTIAL"/>
<setting name="autoMappingUnknownColumnBehavior" value="WARNING"/>
<setting name="defaultExecutorType" value="SIMPLE"/>
<setting name="defaultStatementTimeout" value="25"/>
<setting name="defaultFetchSize" value="100"/>
<setting name="safeRowBoundsEnabled" value="false"/>
<setting name="mapUnderscoreToCamelCase" value="false"/>
<setting name="localCacheScope" value="SESSION"/>
<setting name="jdbcTypeForNull" value="OTHER"/>
<setting name="lazyLoadTriggerMethods" value="equals,clone,hashCode,toString"/>
</settings>

问题:如果在 configuration标签 上出现红色波浪线

鼠标移到该标签出现:The content of element type "configuration" must match "(properties?,settings?,typeAliases?,typeHandlers?,objectFactory?,objectWrapperFactory?,reflectorFactory?,plugins?,environments?,databaseIdProvider?,mappers?)".

解决:因为位置错误,settings标签要放在properties标签后面。

4、查询示例

1、示范:查询功能

1、设置接口

userMapper (接口)

package com.dao;

import com.pojo.User;

import java.util.List;

public interface userMapper {
//查询全部用户
List<User> selectUser();
//根据id查询用户
User selectUserById(int id);
}

2、在userMapper.xml设置SQL语句

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.dao.userMapper"> <!-- 映射器 命名空间:映射到那个类的地址 -->
<select id="selectUser" resultType="User"> <!-- 查询 名:selectUser 结果类型:com.pojo.User -->
select * from user
</select> <select id="selectUserById" resultType="User">
select * from user where id = #{id}
</select>
</mapper>

3、测试

MyTest.java

import com.dao.userMapper;
import com.pojo.User;
import org.apache.ibatis.session.SqlSession;
import org.junit.Test;
import utils.MybatisUtils; import java.util.List; public class MyTest {
@Test
public void selectUser() {
SqlSession session = MybatisUtils.getSession();
userMapper mapper = session.getMapper(userMapper.class); User user = mapper.selectUserById(1);
System.out.println("通过Id查询:"+user); System.out.println("查询所有:");
List<User> userAll = mapper.selectUser();
for (User user1 : userAll) {
System.out.println(user1);
} session.close();
}
}

5、crud实例

com/dao/userMapper (接口)

package com.dao;

import com.pojo.User;

import java.util.List;

public interface userMapper {
//查询全部用户
List<User> selectUser();
//根据id查询用户
User selectUserById(int id);
//添加一个用户
int addUser(User user);
//修改一个用户
int updateUser(User user);
//根据id删除用户
int deleteUser(int id);
}

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.dao.userMapper"> <!-- 映射器 命名空间:映射到那个类的地址 -->
<select id="selectUser" resultType="User"> <!-- 查询 名:selectUser 结果类型:com.pojo.User -->
select * from user
</select> <select id="selectUserById" resultType="User">
select * from user where id = #{id}
</select> <insert id="addUser" parameterType="User">
insert into user (id,name,pwd) values (#{id},#{name},#{pwd})
</insert> <update id="updateUser" parameterType="User">
update user set name=#{name},pwd=#{pwd} where id = #{id}
</update> <delete id="deleteUser" parameterType="int">
delete from user where id = #{id}
</delete>
</mapper>

MyTest.java

import com.dao.userMapper;
import com.pojo.User;
import org.apache.ibatis.session.SqlSession;
import org.junit.Test;
import utils.MybatisUtils; public class MyTest {
@Test
public void selectUser() {
SqlSession session = MybatisUtils.getSession();
userMapper mapper = session.getMapper(userMapper.class); /*通过id查询*/
/* User user = mapper.selectUserById(1);
System.out.println("通过Id查询:"+user);*/ /*查询所有用户*/
/* System.out.println("查询所有:");
List<User> userAll = mapper.selectUser();
for (User user1 : userAll) {
System.out.println(user1);
}*/ /*增加用户*/
/* User user = new User(6,"赵六","chaoliu"); // 到实体类User中设置:有参构造
int i = mapper.addUser(user);
System.out.println(i); // 输出为1,时表示增加一个用户成功
session.commit(); // 提交事务,没有的话交不到数据库*/ /*根据删除*/
/* int i = mapper.deleteUser(6);
System.out.println(i); // 输出为1,表示删除一个用户成功
session.commit(); //提交事务,重点!不写的话不会提交到数据库*/ /*修改*/
User user = mapper.selectUserById(1);
user.setPwd("newPassword");
int i = mapper.updateUser(user);
System.out.println(i);
session.commit(); //提交事务,重点!不写的话不会提交到数据库 session.close();
}
}

mybatis crud 学习总结02的更多相关文章

  1. MyBatis入门学习教程-使用MyBatis对表执行CRUD操作

    上一篇MyBatis学习总结(一)--MyBatis快速入门中我们讲了如何使用Mybatis查询users表中的数据,算是对MyBatis有一个初步的入门了,今天讲解一下如何使用MyBatis对use ...

  2. Mybatis的学习总结二:使用Mybatis对表进行CRUD操作【参考】

    一.使用Mybatis对表进行CRUD操作------基于XML的实现 1.定义SQL的映射文件 2.在conf.xml中进行注册. 2.创建测试类 [具体过程参考:Mybatis的学习总结一] 二. ...

  3. 第04项目:淘淘商城(SpringMVC+Spring+Mybatis) 的学习实践总结【第二天】

    淘淘商城(SpringMVC+Spring+Mybatis)  是传智播客在2015年9月份录制的,几年过去了.由于视频里课上老师敲的代码和项目笔记有些细节上存在出入,只有根据日志报错信息作出适当的调 ...

  4. Redis:学习笔记-02

    Redis:学习笔记-02 该部分内容,参考了 bilibili 上讲解 Redis 中,观看数最多的课程 Redis最新超详细版教程通俗易懂,来自 UP主 遇见狂神说 4. 事物 Redis 事务本 ...

  5. Mybatis架构学习

    Mybatis架构学习 MyBatis 是支持定制化 SQL.存储过程以及高级映射的持久层框架.MyBatis 封装了几乎所有的 JDBC 代码和手动设置参数以及获取结果集.可以对配置和原生Map使用 ...

  6. 软件测试之loadrunner学习笔记-02集合点

    loadrunner学习笔记-02集合点 集合点函数可以帮助我们生成有效可控的并发操作.虽然在Controller中多用户负载的Vuser是一起开始运行脚本的,但是由于计算机的串行处理机制,脚本的运行 ...

  7. MyBatis入门学习(二)

    在MyBatis入门学习(一)中我们完成了对MyBatis简要的介绍以及简单的入门小项目测试,主要完成对一个用户信息的查询.这一节我们主要来简要的介绍MyBatis框架的增删改查操作,加深对该框架的了 ...

  8. Spring+SpringMVC+MyBatis深入学习及搭建(二)——MyBatis原始Dao开发和mapper代理开发

    转载请注明出处:http://www.cnblogs.com/Joanna-Yan/p/6869133.html 前面有写到Spring+SpringMVC+MyBatis深入学习及搭建(一)——My ...

  9. Spring+SpringMVC+MyBatis深入学习及搭建(三)——MyBatis全局配置文件解析

    转载请注明出处:http://www.cnblogs.com/Joanna-Yan/p/6874672.html 前面有写到Spring+SpringMVC+MyBatis深入学习及搭建(二)——My ...

随机推荐

  1. Thread的打断

    常用方法 public void interrupt() t.interrupt() 打断t线程(设置t线程某给标志位f=true,并不是打断线程的运行),不能打断正在竞争锁的线程. public b ...

  2. 云服务器的windows系统上部署项目

    1.购买云服务器 以百度云服务器为例 https://cloud.baidu.com/campaign/midyear2020/index.html?track=cp:npinzhuan|pf:pc| ...

  3. java中使用反射获取pojo(实体)类的所有字段值

    出处:https://developer.aliyun.com/article/239346 说起反射,不得不说它实在是太强大了,通过反射就可以轻轻松松拿到各种东东,如果你想在项目中解除对某个类的依赖 ...

  4. java命令-(学习)jstack 工具

    一.介绍 jstack是java虚拟机自带的一种堆栈跟踪工具.jstack用于打印出给定的java进程ID或core file或远程调试服务的Java堆栈信息,如果是在64位机器上,需要指定选项&qu ...

  5. Python安装pip时, 报错:zipimport.ZipImportError: can't decompress data; zlib not available

    解决办法: 1.安装依赖zlib.zlib-devel 2.重新编译安装Python 具体步骤: 1 到python安装目录下,运行./configure 2 编辑Modules/Setup文件 vi ...

  6. js null和{}区别

    {}是一个不完全空的对象,因为他的原型链上还有Object呢,而null就是完全空的对象,啥也没有,原型链也没有,所以null instanceof Object === false;[]就更不用说了 ...

  7. Nginx+Tomcat 实现负载均衡 ,动静分离集群部署

    Nginx + Tomcat 实现负载均衡,动静分离集群部署 1.Nginx实现负载均衡原理 2.Nginx配置反向代理主要参数 3.实验 1.Nginx实现负载均衡原理: Nginx服务器作为前端, ...

  8. Git配置ssh免密登录

    一.在用户目录下的.ssh目录下生成秘钥与公钥 如果用户目录下没有.ssh目录,则需要新建一个 cd ~/.ssh ssh-keygen -t rsa 一路回车即可 注:国内很多博客都会带上-C &q ...

  9. Linux运行级别及解释

    Linux中有七个运行级别,分别为0~7 0级:关机 1级:单用户(找回丢失密码) 2级:多用户无网络 3级:多用户有网络,最常用的级别 4级:保留,目前Linux暂无使用 5级:图像界面 6级:重启 ...

  10. 第11、12章等待方法和alter框处理

    11.等待方法 time sleep webdriver implicitly_wait() 设置浏览器等待时间 WebDriverWait 等待条件满足或超时后退出   12.alter对话框处理 ...