Ajout, suppression et modification simples de mybatis

Manon romantique 2021-11-25 17:40:16
ajout suppression et modification simples

MybatisAjouter, supprimer, modifier et vérifier

C'est ma participation11Le défi du mois de juin25Oh, mon Dieu.,Voir les détails de l'événement:2021Un dernier défi

J'ai commencé à étudierMybatisVous pouvez d'abord consulter les documents officiels,MyBatisPrise en charge de la personnalisationSQL、Un excellent cadre de persistance pour les procédures stockées et la cartographie avancée.MyBatisA évité presque toutJDBCCode et réglage manuel des paramètres et extraction des ensembles de résultats.MyBatisSimple à utiliserXMLOu des annotations pour configurer et cartographier les primitives,Interface etJavaDePOJOs(Plain Old Java Objects,OrdinaireJavaObjet)Cartographie des enregistrements dans la base de données.

Passons au sujet: Outils:Navicat premium 、IntelliJ IDEA

Structure simple du Répertoire

image.png

1.CréationmysqlBase de données

image.png Créer unfirend_mqBase de données, Créer un tableau pour users ,Et insérer quelques données

2.Créer un nouveaumavenProjets,Et importer des dépendances

 <dependencies>
<!-- https://mvnrepository.com/artifact/org.mybatis/mybatis -->
<!--AjoutermybatisDépendance-->
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.4.6</version>
</dependency>
<!--jdbcDrive-->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.47</version>
</dependency>
<!--junitCatégorie d'essai-->
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.12</version>
<scope>test</scope>
</dependency>
</dependencies>
Copier le Code

3.InresourcesNouveau sous le dossiermybatis-config.xml,CompilationmybaitsProfil de base pour

<?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">
<!-- configurationProfil de base-->
<configuration>
<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://localhost:3306/firend_mq?useSSL=false&amp;useUnicode=&amp;characterEncodeing=UTF-8"/>
<property name="username" value="root"/>
<property name="password" value="root"/>
</dataSource>
</environment>
</environments>
<!-- Inscriptionmapper-->
<mappers>
<mapper resource="dao/UserMapper.xml"/>
</mappers>
</configuration>
Copier le Code

Attention:resourceBINDmapper,Chemin requis,Utiliser"/" Connexionmysql Des problèmes de fuseau horaire peuvent survenir avec la base de données ,Vous pouvez lire ce blog IntelliJ IDEAConnexionMysql Base de données et problèmes rencontrés (Plus de détails)

4.CompilationmybatisClasse d'outils

//SqlSessionFactory
public class Mybatisutil {
private static SqlSessionFactory sqlSessionFactory;
static {
try {//Utilisermybaatis Étape 1 SqlSessionFactoryObjet
String resource="mybatis-config.xml";
InputStream inputStream= Resources.getResourceAsStream(resource);
sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
} catch (IOException e) {
e.printStackTrace();
}
}
//C'est bon. SqlSessionFactory,Comme son nom l'indique,On peut en tirer SqlSession Exemples.SqlSession
// Fournit l'exécution dans la base de données SQL Toutes les méthodes nécessaires pour commander.Vous pouvez passer par SqlSession Instance pour exécuter directement SQL Déclarations
public static SqlSession getSqlSession(){
SqlSession sqlSession = sqlSessionFactory.openSession();
return sqlSession;
}
}
Copier le Code

5.CompilationmybatisClasse d'entité

package pojo;
public class User {
private int id;
private String username;
private String password;
public User(int id, String username, String password) {
this.id = id;
this.username = username;
this.password = password;
}
public User() {
}
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
@Override
public String toString() {
return "User{" +
"id=" + id +
", username='" + username + '\'' +
", password='" + password + '\'' +
'}';
}
}
Copier le Code

Les préparatifs préliminaires sont terminés ,Commencez à écrire le Code

6.CompilationDaoInterface de la couche

public interface UserDao {
//Interroger tous les utilisateurs
List<User> getUserList();
//Requête assignéeidUtilisateurs
User getUserById(int id);
//Ajouter un utilisateur
int addUser(User user);
//Modifier l'utilisateur
int updateUser(User user);
//Supprimer un utilisateur
int deleteUser(int id);
}
Copier le Code

7.Écrire une classe d'implémentation d'interface La classe d'implémentation de l'interface a été créée parUserDaoImplConvertir enMapperConfigurer le dossier

<!--namespace=Lier unDao/MapperInterface-->
<mapper namespace="dao.UserDao">
<!-- selectInstruction de requête -->
<select id="getUserList" resultType="pojo.User">
select * from firend_mq.users
</select>
<!-- SelonidRequête-->
<select id="getUserById" parameterType="int" resultType="pojo.User">
select * from firend_mq.users where id = #{id}
</select>
<!-- Ajouter un utilisateur Propriétés dans l'objet, Peut être retiré directement -->
<insert id="addUser" parameterType="pojo.User">
insert into firend_mq.users (id,username,password) value (#{id},#{username},#{password})
</insert>
<update id="updateUser" parameterType="pojo.User">
update firend_mq.users set username=#{username},password=#{password} where id=#{id};
</update>
<!-- Supprimer un utilisateur-->
<delete id="deleteUser" parameterType="int">
delete from firend_mq.users where id=#{id}
</delete>
</mapper>
Copier le Code

Attention:

  • Mapper Le Profil doit être situé à mybatis-config.xmlInscription à l'intérieur
  • L'étiquette est le type d'ajout, de suppression et de modification , Écrivez l'original sur l'étiquette sqlDéclarations,Utiliser#{}Transmission de la valeur
  • namespace=Lier unDao/MapperInterface, Ne pas lier les mauvaises interfaces
  • id C'est le nom de la méthode dans l'interface ,Soyez cohérent.
  • parameterType Est le type de paramètre de la méthode ,resultType Est le type de valeur de retour de la méthode pour correspondre à l'interface .

8.Écrire une classe de test

public class UserDaoText {
//Interroger tous les utilisateurs
@Test
public void getUserList(){
//Première étape:ObtenirsqlSessionObjet
SqlSession sqlSession = Mybatisutil.getSqlSession();
//Mode 1:getMapper
UserDao mapper = sqlSession.getMapper(UserDao.class);
List<User> userList = mapper.getUserList();
for (User user : userList) {
System.out.println(user);
}
sqlSession.close();
}
// Requête assignéeidUtilisateurs
@Test
public void getUserById(){
SqlSession sqlSession = Mybatisutil.getSqlSession();
UserDao mapper = sqlSession.getMapper(UserDao.class);
User user = mapper.getUserById(2);
System.out.println(user);
sqlSession.close();
}
// Tous les ajouts, suppressions et modifications doivent être soumis à la transaction 
//Ajouter un utilisateur
@Test
public void addUser(){
SqlSession sqlSession = Mybatisutil.getSqlSession();
UserDao mapper = sqlSession.getMapper(UserDao.class);
mapper.addUser(new User(4,"Zhang San","10086"));
//Soumettre une transaction
sqlSession.commit();
sqlSession.close();
}
@Test
public void updateUser(){
SqlSession sqlSession = Mybatisutil.getSqlSession();
UserDao mapper = sqlSession.getMapper(UserDao.class);
mapper.updateUser(new User(4,"Ha Ha!","123"));
sqlSession.commit();
sqlSession.close();
}
@Test
public void deleteUser(){
SqlSession sqlSession = Mybatisutil.getSqlSession();
UserDao mapper = sqlSession.getMapper(UserDao.class);
mapper.deleteUser(4);
sqlSession.commit();
sqlSession.close();
}
}
Copier le Code

Une telle simplicité Mybatis L'ajout, la suppression, la modification et la recherche de , Les détails sont indiqués dans le Code par un commentaire .

版权声明
本文为[Manon romantique]所创,转载请带上原文链接,感谢
https://javamana.com/2021/11/20211125174014043u.html

  1. http://lx.gongxuanwang.com/sszt/32.htm
  2. 回顾我两个月面试阿里,携程,小红书,美团,网易等等(Java岗)
  3. JavaScript高级程序设计读后感(一)之零碎知识点查漏补缺
  4. http://lx.gongxuanwang.com/sszt/7.htm
  5. #yyds干货盘点#设计模式之【工厂模式】
  6. Java * SpringBoot实现万能文件在线预览,已开源,真香
  7. Redis | 第4章 Redis中的数据库《Redis设计与实现》
  8. Redis | 第4章 Redis中的数据库《Redis设计与实现》
  9. 关于centos docker版本过低导致 is not a valid repository/tag: invalid reference format
  10. Redis 源码简洁剖析 02 - SDS 字符串
  11. 回顧我兩個月面試阿裏,攜程,小紅書,美團,網易等等(Java崗)
  12. Rétrospectivement, j'ai passé deux mois à interviewer Ali, ctrip, Little Red Book, meituan, NetEase, etc. (Java post)
  13. Docker + webhook Automation Deployment Front End Project
  14. Java技术之Spring、Hibernate框架整合方法
  15. http://lx.gongxuanwang.com/sszt/32.htm
  16. 亚马逊自己的 Linux 发行版现在完全基于 Fedora 了
  17. Redis 源码简洁剖析 02 - SDS 字符串
  18. Java技術之Spring、Hibernate框架整合方法
  19. Méthode d'intégration des cadres de printemps et d'hibernation de la technologie Java
  20. Redis source Concise Analysis 02 - SDS String
  21. La distribution Linux d'Amazon est maintenant entièrement basée sur Fedora
  22. org.springframework.web.bind.MissingServletRequestParameterException
  23. Built in constraints and functions of MySQL Foundation (2)
  24. Basic operation of MySQL Foundation (I)
  25. Introduction to Java zero foundation 3: Java data types
  26. 从零开始搭建EasyDarwin环境——Linux系统开发环境搭建Golang
  27. Redis source Concise Analysis 02 - SDS String
  28. Construire l'environnement easydarwin à partir de zéro - - construire l'environnement de développement du système Linux golang
  29. javaweb代码是正确的,但是第一行代码就报错了
  30. **** | Java | 后端开挂:3行代码写出8个接口
  31. Java || 看了大二学长写的代码,我竟开始默默的模仿了。。。
  32. Java | 手把手教你实现一个抽奖系统(Java版)
  33. Java | Manuel pour vous apprendre à mettre en œuvre un système de loterie (version Java)
  34. Java | | après avoir lu le Code que j'ai écrit en deuxième année, j'ai commencé à imiter silencieusement...
  35. Java | back - end Pending: 3 - line Code write 8 Interfaces
  36. Le Code Web Java est correct, mais la première ligne de code est incorrecte
  37. Android网络编程之Http通信
  38. Android網絡編程之Http通信
  39. Http communication for Android Network Programming
  40. 数据结构实验八 领会图的两种主要储存结构和图的基本运算算法设计
  41. Hibernate数据校验简介
  42. The story of spring
  43. Il a dépensé 270 000 yuans pour soulever Xiaopeng p7 et a parcouru 3 627 km. Le propriétaire du véhicule a partagé 6 avantages et inconvénients.
  44. 阿里蚂蚁花呗团队面试题:spring+分布式+jvm+session+redis
  45. 【Java入门100例】14.字符串排序——compareTo()
  46. 【Java入门100例】13.修改文件扩展名——字符串替换
  47. Leetcode 79. Word Search [C + + / java detailed problem]
  48. Introduction à la vérification des données hibernantes
  49. Expérience de la structure des données
  50. Spring cloud gateway practice 2: more routing configuration methods
  51. Java network programming - summary overview
  52. 基于语法树的 Java 代码自动化插桩
  53. 云原生 Spring Boot 应用配置 Prometheus + Grafana 监控(保姆级)
  54. Spring cloud gateway practice 2: more routing configuration methods
  55. Jenkins file one line of code to deploy. Net program to k8s
  56. Java network programming - summary overview
  57. Cloud Native Spring Boot application configuration Prometheus + grafana Monitoring (baby - sitter)
  58. Insertion automatique de code Java basée sur l'Arbre syntaxique
  59. Le SUV phare de Xiaopeng, Xiaopeng G9, a fait ses débuts au salon de l'automobile et s'est tenu en position C dans la nouvelle force?
  60. Docker 从入门到实践系列四 - Docker 容器编排利器 Docker Compose