最后完成的目录结构如下:
2、在pom.xml中导入相关的依赖
pom.xml:
<?xml version="1.0" encoding="UTF-8"?><project xmlns=“http://maven.apache.org/POM/4.0.0”
xmlns:xsi=“http://www.w3.org/2001/XMLSchema-instance”
xsi:schemaLocation=“http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd”>
4.0.0
com.keafmd
day01_eesy_01mybatis
1.0-SNAPSHOT
jar
org.mybatis
mybatis
3.5.5
mysql
mysql-connector-java
5.1.49
log4j
log4j
1.2.17
junit
junit
4.13
test
3、准备数据库
创建个数据库eesy_mybatis
,入门案例中只使用到了user表。
sql文件:
DROP TABLE IF EXISTS user
;
CREATE TABLE user
(
id
int(11) NOT NULL auto_increment,
username
varchar(32) NOT NULL COMMENT ‘用户名称’,
birthday
datetime default NULL COMMENT ‘生日’,
sex
char(1) default NULL COMMENT ‘性别’,
address
varchar(256) default NULL COMMENT ‘地址’,
PRIMARY KEY (id
)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
insert into user
(id
,username
,birthday
,sex
,address
) values (41,‘老王’,‘2018-02-27 17:47:08’,‘男’,‘北京’),(42,‘小二王’,‘2018-03-02 15:09:37’,‘女’,‘北京金燕龙’),(43,‘小二王’,‘2018-03-04 11:34:34’,‘女’,‘北京金燕龙’),(45,‘传智播客’,‘2018-03-04 12:04:06’,‘男’,‘北京金燕龙’),(46,‘老王’,‘2018-03-07 17:37:26’,‘男’,‘北京’),(48,‘小马宝莉’,‘2018-03-08 11:44:00’,‘女’,‘北京修正’);
DROP TABLE IF EXISTS account
;
CREATE TABLE account
(
ID
int(11) NOT NULL COMMENT ‘编号’,
UID
int(11) default NULL COMMENT ‘用户编号’,
MONEY
double default NULL COMMENT ‘金额’,
PRIMARY KEY (ID
),
KEY FK_Reference_8
(UID
),
CONSTRAINT FK_Reference_8
FOREIGN KEY (UID
) REFERENCES user
(id
)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
insert into account
(ID
,UID
,MONEY
) values (1,41,1000),(2,45,1000),(3,41,2000);
DROP TABLE IF EXISTS role
;
CREATE TABLE role
(
ID
int(11) NOT NULL COMMENT ‘编号’,
ROLE_NAME
varchar(30) default NULL COMMENT ‘角色名称’,
ROLE_DESC
varchar(60) default NULL COMMENT ‘角色描述’,
PRIMARY KEY (ID
)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
insert into role
(ID
,ROLE_NAME
,ROLE_DESC
) values (1,‘院长’,‘管理整个学院’),(2,‘总裁’,‘管理整个公司’),(3,‘校长’,‘管理整个学校’);
DROP TABLE IF EXISTS user_role
;
CREATE TABLE user_role
(
UID
int(11) NOT NULL COMMENT ‘用户编号’,
RID
int(11) NOT NULL COMMENT ‘角色编号’,
PRIMARY KEY (UID
,RID
),
KEY FK_Reference_10
(RID
),
CONSTRAINT FK_Reference_10
FOREIGN KEY (RID
) REFERENCES role
(ID
),
CONSTRAINT FK_Reference_9
FOREIGN KEY (UID
) REFERENCES user
(id
)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
insert into user_role
(UID
,RID
) values (41,1),(45,1),(41,2);
4、编写User实体类
User类:
package com.keafmd.domain;
import java.util.Date;
/**
-
Keafmd
-
@ClassName: User
-
@Description: user实体类
-
@author: 牛哄哄的柯南
-
@date: 2021-02-06 19:26
*/
public class User {
private Integer id;
private String username;
private Date birthday;
private String sex;
private String address;
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 Date getBirthday() {
return birthday;
}
public void setBirthday(Date birthday) {
this.birthday = birthday;
}
public String getSex() {
return sex;
}
public void setSex(String sex) {
this.sex = sex;
}
public String getAddress() {
return address;
}
public void setAddress(String address) {
this.address = address;
}
@Override
public String toString() {
return “User{” +
“id=” + id +
“, username='” + username + ‘’’ +
“, birthday=” + birthday +
“, sex='” + sex + ‘’’ +
“, address='” + address + ‘’’ +
‘}’;
}
}
5、编写持久层接口 IUserDao
IUserDao:
package com.keafmd.dao;
import com.keafmd.domain.User;
import java.util.List;
/**
-
Keafmd
-
@ClassName: IUserDao
-
@Description: 用户的持久层接口
-
@author: 牛哄哄的柯南
-
@date: 2021-02-06 19:29
*/
public interface IUserDao {
/**
-
查询所有操作
-
@return
*/
List findAll();
}
6、编写持久层接口的映射文件 IUserDao.xml
**要求:
创建位置:必须和持久层接口在相同的包中。
名称:必须以持久层接口名称命名文件名,扩展名是.xml**
IUserDao.xml:
<?xml version="1.0" encoding="UTF-8"?>select * from user
7、编写 SqlMapConfig.xml 配置文件
SqlMapConfig.xml:
<?xml version="1.0" encoding="UTF-8"?>8、引入log4j.properties文件
log4j.properties:
Set root category priority to INFO and its only appender to CONSOLE.
#log4j.rootCategory=INFO, CONSOLE debug info warn error fatal
log4j.rootCategory=debug, CONSOLE, LOGFILE
Set the enterprise logger category to FATAL and its only appender to CONSOLE.
log4j.logger.org.apache.axis.enterprise=FATAL, CONSOLE
CONSOLE is set to be a ConsoleAppender using a PatternLayout.
log4j.appender.CONSOLE=org.apache.log4j.ConsoleAppender
log4j.appender.CONSOLE.layout=org.apache.log4j.PatternLayout
log4j.appender.CONSOLE.layout.ConversionPattern=%d{ISO8601} %-6r [%15.15t] %-5p %30.30c %x - %m\n
LOGFILE is set to be a File appender using a PatternLayout.
log4j.appender.LOGFILE=org.apache.log4j.FileAppender
log4j.appender.LOGFILE.File=d:\axis.log
log4j.appender.LOGFILE.Append=true
log4j.appender.LOGFILE.layout=org.apache.log4j.PatternLayout
log4j.appender.LOGFILE.layout.ConversionPattern=%d{ISO8601} %-6r [%15.15t] %-5p %30.30c %x - %m\n
9、编写测试类
**第一步:读取配置文件
第二步:创建SqlSessionFactory工厂
第三步:创建SqlSession
第四步:创建Dao接口的代理对象
第五步:执行dao中的方法
第六步:释放资源**
MybatisTest:
package com.keafmd.test;
import com.keafmd.dao.IUserDao;
import com.keafmd.domain.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 javax.annotation.Resource;
import java.io.InputStream;
import java.util.List;
/**
-
Keafmd
-
@ClassName: MybatisTest
-
@Description: 测试类
-
@author: 牛哄哄的柯南
-
@date: 2021-02-06 19:55
*/
public class MybatisTest {
/**
-
入门案例
-
@param args
*/
public static void main(String[] args) throws Exception{
//1.读取配置文件
InputStream in = Resources.getResourceAsStream(“SqlMapConfig.xml”);
//2.创建SqlSessionFactory工厂
SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();
SqlSessionFactory factory = builder.build(in);
//3.使用工厂生产SqlSession对象
SqlSession session = factory.openSession();
//4.使用SqlSession创建Dao接口的代理对象
IUserDao userDao = session.getMapper(IUserDao.class);
//5.使用代理对象执行方法
List users = userDao.findAll();
for (User user : users) {
System.out.println(user);
}
//6.释放资源
session.close();
in.close();
}
}
运行结果
2021-02-06 20:50:29,169 0 [ main] DEBUG ache.ibatis.logging.LogFactory - Logging initialized using ‘class org.apache.ibatis.logging.log4j.Log4jImpl’ adapter.
最后
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助。
因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点!不论你是刚入门Android开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门!
如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
DEBUG ache.ibatis.logging.LogFactory - Logging initialized using ‘class org.apache.ibatis.logging.log4j.Log4jImpl’ adapter.
最后
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助。
因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
[外链图片转存中…(img-RPfAhVCo-1715574215948)]
[外链图片转存中…(img-HkFVAwGH-1715574215948)]
[外链图片转存中…(img-bMxVJ1Gy-1715574215949)]
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点!不论你是刚入门Android开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门!
如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!