Java:MyBatis+SQLite使用实例

举报
彭世瑜 发表于 2021/08/14 01:39:52 2021/08/14
【摘要】 MyBatis: https://mybatis.org/mybatis-3/zh/index.html 项目结构 $ tree . ├── data.db # 数据库文件 ├── pom.xml └── src └── main ├── java │ └── com │ └── mouday │ ├── App.java │ ├── dao │ │ ├──...

MyBatis:
https://mybatis.org/mybatis-3/zh/index.html

项目结构

$ tree
.
├── data.db # 数据库文件
├── pom.xml
└── src └── main ├── java │   └── com │ └── mouday │ ├── App.java │ ├── dao │ │   ├── PersonDao.java │ │   └── impl │ │ └── PersonDaoImpl.java │ ├── pojo │ │   └── Person.java │ └── util │ └── MyBatisUtil.java └── resources ├── db.properties ├── mapper │   └── PersonMapper.xml └── mybatis-config.xml

  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23

配置文件

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"> <modelVersion>4.0.0</modelVersion> <groupId>com.mouday</groupId> <artifactId>demo</artifactId> <version>1.0-SNAPSHOT</version> <name>demo</name> <!-- FIXME change it to the project's website --> <url>http://www.example.com</url> <properties> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> <maven.compiler.source>1.8</maven.compiler.source> <maven.compiler.target>1.8</maven.compiler.target> </properties> <dependencies> <dependency> <groupId>org.xerial</groupId> <artifactId>sqlite-jdbc</artifactId> <version>3.32.3</version> </dependency> <dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis</artifactId> <version>3.5.5</version> </dependency> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>4.11</version> <scope>test</scope> </dependency> </dependencies>

</project>


  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45

db.properties

driver=org.sqlite.JDBC
url=jdbc:sqlite:data.db

  
 
  • 1
  • 2

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> <!-- 加载数据库配置 --> <properties resource="db.properties" /> <!-- 打印sql日志 --> <settings> <setting name="logImpl" value="STDOUT_LOGGING"/> </settings> <!-- 指定整个包下的类都是别名 --> <typeAliases> <package name="com.mouday.pojo"/> </typeAliases> <environments default="development"> <environment id="development"> <transactionManager type="JDBC"/> <dataSource type="POOLED"> <property name="driver" value="${driver}"/> <property name="url" value="${url}"/> </dataSource> </environment> </environments> <!-- 映射文件 --> <mappers> <mapper resource="mapper/PersonMapper.xml"/> </mappers>
</configuration>

  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34

工具类

MyBatisUtil.java

package com.mouday.util;


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 java.io.IOException;
import java.io.InputStream;

public class MyBatisUtil { private static SqlSessionFactory factory = null; // 使用static静态代码块,随着类的加载而加载,只执行一次 static { try { String resource = "mybatis-config.xml"; // 加载MyBatis的主配置文件 InputStream inputStream = Resources.getResourceAsStream(resource); // 通过构建器(SqlSessionFactoryBuilder)构建一个SqlSessionFactory工厂对象 factory = new SqlSessionFactoryBuilder().build(inputStream); } catch (Exception e) { e.printStackTrace(); } } public static SqlSession getSqlSession() throws IOException { return factory.openSession(); }
}



  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34

POJO

Plain Ordinary Java Object

Person.java

package com.mouday.pojo;

public class Person { private Integer id; private String name; private Integer age; public Person(String name, Integer age) { this.name = name; this.age = age; } public Integer getId() { return id; } public void setId(Integer id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } public Integer getAge() { return age; } public void setAge(Integer age) { this.age = age; } @Override public String toString() { return "Person{" + "id=" + id + ", name='" + name + '\'' + ", age=" + age + '}'; }
}


  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46

DAO

Data Access Object

PersonDao.java

package com.mouday.dao;

import com.mouday.pojo.Person;

import java.util.List;


public interface PersonDao { Integer createTable(); Integer dropTable(); List<Person> selectAll(); Person selectById(Integer id); Integer deleteById(Integer id); Integer update(Person person); Integer insert(Person person);

}


  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18

PersonDaoImpl.java

package com.mouday.dao.impl;

import com.mouday.dao.PersonDao;
import com.mouday.pojo.Person;
import com.mouday.util.MyBatisUtil;
import org.apache.ibatis.session.SqlSession;

import java.io.IOException;
import java.util.List;

public class PersonDaoImpl implements PersonDao { public Integer createTable() { try (SqlSession session = MyBatisUtil.getSqlSession()) { PersonDao mapper = session.getMapper(PersonDao.class); Integer result = mapper.createTable(); session.commit(); return result; } catch (IOException e) { e.printStackTrace(); } return 0; } @Override public Integer dropTable() { try (SqlSession session = MyBatisUtil.getSqlSession()) { PersonDao mapper = session.getMapper(PersonDao.class); Integer result = mapper.dropTable(); session.commit(); return result; } catch (IOException e) { e.printStackTrace(); } return 0; } @Override public List<Person> selectAll() { List<Person> list = null; try (SqlSession session = MyBatisUtil.getSqlSession()) { // Person person = session.selectOne("com.mouday.dao.PersonDao.selectById", 1); // 等价于 PersonDao mapper = session.getMapper(PersonDao.class); list = mapper.selectAll(); } catch (IOException e) { e.printStackTrace(); } return list; } public Person selectById(Integer id) { Person person = null; try (SqlSession session = MyBatisUtil.getSqlSession()) { // Person person = session.selectOne("com.mouday.dao.PersonDao.selectById", 1); // 等价于 PersonDao mapper = session.getMapper(PersonDao.class); person = mapper.selectById(id); } catch (IOException e) { e.printStackTrace(); } return person; } public Integer deleteById(Integer id) { try (SqlSession session = MyBatisUtil.getSqlSession()) { PersonDao mapper = session.getMapper(PersonDao.class); Integer result = mapper.deleteById(id); session.commit(); return result; } catch (IOException e) { e.printStackTrace(); } return 0; } public Integer insert(Person person) { try (SqlSession session = MyBatisUtil.getSqlSession()) { PersonDao mapper = session.getMapper(PersonDao.class); Integer result = mapper.insert(person); session.commit(); return result; } catch (IOException e) { e.printStackTrace(); } return 0; } public Integer update(Person person) { try (SqlSession session = MyBatisUtil.getSqlSession()) { PersonDao mapper = session.getMapper(PersonDao.class); Integer result = mapper.update(person); session.commit(); return result; } catch (IOException e) { e.printStackTrace(); } return 0; }
}


  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54
  • 55
  • 56
  • 57
  • 58
  • 59
  • 60
  • 61
  • 62
  • 63
  • 64
  • 65
  • 66
  • 67
  • 68
  • 69
  • 70
  • 71
  • 72
  • 73
  • 74
  • 75
  • 76
  • 77
  • 78
  • 79
  • 80
  • 81
  • 82
  • 83
  • 84
  • 85
  • 86
  • 87
  • 88
  • 89
  • 90
  • 91
  • 92
  • 93
  • 94
  • 95
  • 96
  • 97
  • 98
  • 99
  • 100
  • 101
  • 102
  • 103
  • 104
  • 105
  • 106
  • 107
  • 108
  • 109
  • 110
  • 111
  • 112
  • 113

PersonMapper.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.mouday.dao.PersonDao"> <update id="dropTable"> drop table if exists person; </update> <update id="createTable"> CREATE TABLE IF NOT EXISTS `person` ( `id` INTEGER NOT NULL PRIMARY KEY AUTOINCREMENT, `name` TEXT, `age` INTEGER ) </update> <select id="selectAll" resultType="Person"> select * from person </select> <select id="selectById" resultType="Person"> select * from person where id = #{id} limit 1 </select> <delete id="deleteById"> delete from person where id = #{id} </delete> <insert id="insert" useGeneratedKeys="true"> insert into person (name, age) values (#{name}, #{age}) </insert> <update id="update"> update person set name = #{name}, age = #{age} where id = #{id} </update>
</mapper>

  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40

接口使用

App.java

package com.mouday;

import com.mouday.dao.PersonDao;
import com.mouday.dao.impl.PersonDaoImpl;
import com.mouday.pojo.Person;


import java.io.IOException;
import java.util.List;


public class App { public static void main(String[] args) throws IOException { PersonDao personDao = new PersonDaoImpl(); // 建表 personDao.dropTable(); personDao.createTable(); // 插入数据 personDao.insert(new Person("曹操", 23)); personDao.insert(new Person("刘备", 24)); personDao.insert(new Person("孙权", 21)); // 删除 Integer deleteResult = personDao.deleteById(1); System.out.println(deleteResult); // 查询单个 Person person = personDao.selectById(2); System.out.println(person); // 更新 person.setAge(25); Integer updateResult = personDao.update(person); System.out.println(updateResult); // 查询所有 List<Person> list = personDao.selectAll(); for(Person p: list){ System.out.println(p); } }
}


  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51

完整代码:

https://github.com/mouday/MyBatis-demo

文章来源: pengshiyu.blog.csdn.net,作者:彭世瑜,版权归原作者所有,如需转载,请联系作者。

原文链接:pengshiyu.blog.csdn.net/article/details/107307390

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。