MyBatis(增删改查)
1、工程中引入包:
mybatis-3.2.7、mysql-connector-java-5.1.22-bin
2、添加配置文件:
<?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>
<typeAliases>
<typeAlias alias="Person" type="com.example.mdemo.model.Person"/>
</typeAliases> <environments default="development">
<environment id="development">
<transactionManager type="JDBC"/>
<dataSource type="POOLED">
<property name="driver" value="com.mysql.jdbc.Driver"/>
<property name="url" value="jdbc:mysql://127.0.0.1:3306/demo01" />
<property name="username" value="root"/>
<property name="password" value="root"/>
</dataSource>
</environment>
</environments> <mappers>
<mapper resource="com/example/mdemo/model/Person.xml"/>
</mappers>
</configuration>
3、定义模型和接口JAVA类,如下:
public class Person { private String FirstName;
private String LastName;
private int Age;
public String getFirstName() {
return FirstName;
}
public void setFirstName(String firstName) {
FirstName = firstName;
}
public String getLastName() {
return LastName;
}
public void setLastName(String lastName) {
LastName = lastName;
}
public int getAge() {
return Age;
}
public void setAge(int age) {
Age = age;
}
}
public interface IPersonOperation { public Person selectPersonsByFirstName(String FirstName); public List<Person> selectPersons(String FirstName); public void addPerson(Person person); public void updatePerson(Person person); public void deletePerson(String FirstName); }
4、配置对应的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.example.mdemo.service.IPersonOperation">
<select id="selectPersonsByFirstName" parameterType="String" resultType="Person">
select * from `persons` where FirstName = #{FirstName} limit 1
</select> <select id="selectPersons" parameterType="string" resultMap="resultListPersons">
select * from persons where FirstName like #{FirstName}
</select> <resultMap type="Person" id="resultListPersons">
<result column="FirstName" property="FirstName" />
<result column="LastName" property="LastName" />
<result column="Age" property="Age" />
</resultMap> <insert id="addPerson" parameterType="Person">
insert into persons(FirstName,LastName,Age)
values(#{FirstName},#{LastName},#{Age})
</insert> <update id="updatePerson" parameterType="Person" >
update persons set FirstName=#{FirstName},LastName=#{LastName},Age=#{Age} where FirstName=#{FirstName}
</update> <delete id="deletePerson" parameterType="String">
delete from persons where FirstName=#{FirstName}
</delete> </mapper>
5、测试使用如下:
public class Test {
private static SqlSessionFactory sqlSessionFactory;
private static Reader reader; static{
try{
reader = Resources.getResourceAsReader("config/Configuration.xml");
sqlSessionFactory = new SqlSessionFactoryBuilder().build(reader);
}catch(Exception e){
e.printStackTrace();
}
} public static SqlSessionFactory getSession(){
return sqlSessionFactory;
} public static void main(String[] args) {
SqlSession session = sqlSessionFactory.openSession();
/* try {
Person user = (Person) session.selectOne("com.example.mdemo.model.PersonMapper.selectPersonsByFirstName", "FPPAU");
System.out.println(user.getFirstName());
System.out.println(user.getLastName());
System.out.println(user.getAge());
} finally {
session.close();
}*/ try{
IPersonOperation personOperation = session.getMapper(IPersonOperation.class);
Person person = personOperation.selectPersonsByFirstName("FPPAU");
System.out.println(person.getFirstName());
System.out.println(person.getLastName());
System.out.println(person.getAge()); List<Person> persons = personOperation.selectPersons("FPPAU");
for(Person p:persons){
System.out.println(p.getFirstName());
System.out.println(p.getLastName());
System.out.println(p.getAge());
} System.out.println(persons.size()); Person pp = new Person();
pp.setFirstName("Xu");
pp.setLastName("OK");
pp.setAge(40); personOperation.addPerson(pp);
session.commit(); Person ppp = new Person();
ppp.setFirstName("Xu");
ppp.setLastName("OK");
ppp.setAge(20); personOperation.updatePerson(ppp);
session.commit(); personOperation.deletePerson("FPPAU");
session.commit(); session.commit(); }finally{
session.close();
}
}
}
MyBatis(增删改查)的更多相关文章
- MyBatis增删改查
MyBatis的简介: MyBatis 本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了google code,并且改名 ...
- 【Mybatis】简单的mybatis增删改查模板
简单的mybatis增删改查模板: <?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE map ...
- MyBatis增删改查模板
1. 首先,和Spring整合一下 <?xml version="1.0" encoding="UTF-8"?> <beans xmlns=& ...
- 最简单的mybatis增删改查样例
最简单的mybatis增删改查样例 Book.java package com.bookstore.app; import java.io.Serializable; public class Boo ...
- Mybatis增删改查,Demo整合
第一步:MyBatis的Jar包引入mybatis-3.2.7.jarmysql-connector-java-5.1.8.jar MyBatis的pom.xml依赖 <dependencies ...
- Mybatis增删改查(CURD)
前面的小节我们已经讲到用接口的方式编程.使用这种方式,需要注意的一个地方就是,在User.xml 配置文件中,mapper namespace="com.yiibai.mybatis.int ...
- springboot整合mybatis增删改查(四):完善增删改查及整合swgger2
接下来就是完成增删改查的功能了,首先在config包下配置Druid数据连接池,在配置之前先把相关配置在application.preperties中完善 application.preperties ...
- SpringBoot+Mybatis增删改查实战
简介 SpringBoot和Mybatis是啥请自行百度,作者这里也是花了几天时间入门了这个框架用来完成任务,并且也算符合要求的完成了任务,期间也各种百度但是没找到自己想要的那种简单易懂的教程,所以踩 ...
- springboot&mybatis 增删改查系列(二)
数据库篇 我的数据库名为data0525,数据表名为user,其中有五列uid,uname,upass,usex,umessage.uid为主键并且自动生成,由于是练习表,所以并没有考虑设计的合理性. ...
- springboot2之结合mybatis增删改查解析
1. 场景描述 本节结合springboot2.springmvc.mybatis.swagger2等,搭建一个完整的增删改查项目,希望通过这个基础项目,能帮忙朋友快速上手springboot2项目. ...
随机推荐
- Linux下安装Tomcat服务器和部署Web应用
一.上传Tomcat服务器
- 《DSP using MATLAB》第6章开始了
看到第6章了,标记一下,全书近一半,继续加油 构建滤波器的三种元件: 下面是函数floor和size的部分帮助截图
- time的用法
线程计时器(System.Threading.Timer) System.Windows.Threading.DispatcherTimer tRecorderTimer; if (tRecorder ...
- C#对象序列化与反序列化zz
C#对象序列化与反序列化(转载自:http://www.cnblogs.com/LiZhiW/p/3622365.html) 1. 对象序列化的介绍........................ ...
- 【HDU2896】病毒侵袭 AC自动机
[HDU2896]病毒侵袭 Problem Description 当太阳的光辉逐渐被月亮遮蔽,世界失去了光明,大地迎来最黑暗的时刻....在这样的时刻,人们却异常兴奋--我们能在有生之年看到500年 ...
- @WebServlet用注解来实现servlet和url的映射
package com.servlet; import java.io.IOException; import java.io.PrintWriter; import javax.servlet.Se ...
- 队列的JS实现
队列和栈相似,都是对插入和删除操作的部位做了限制特殊的线性表.在队列中,只能从一头删除节点,这一头叫做队首:而另一端只能做插入操作,这一头叫做队尾.很容易理解,队列是一个"先进先出" ...
- centos中docker mongodb 配置
安装docker,对于Centos7,如下: $ sudo yum update$ sudo yum -y install docker$ sudo systemctl start docker 首先 ...
- iOS中 将 颜色转化成图片
定义一个类方法: 声明: + (UIImage *)imageFromColor:(UIColor *)color; 实现: + (UIImage *)imageFromColor:(UIColor ...
- 第一天---HTML基础学习
HTML(hyper text markup language) HTML不是一种编程语言,而是一种标记语言(markup language),标记语言是一套markup tag(标记标签),HTML ...