Rumah > Java > javaTutorial > Laksanakan pemetaan ORM berdasarkan Spring Boot dan MyBatis Plus

Laksanakan pemetaan ORM berdasarkan Spring Boot dan MyBatis Plus

王林
Lepaskan: 2023-06-22 21:27:42
asal
974 orang telah melayarinya

Dalam proses pembangunan aplikasi web Java, teknologi pemetaan ORM (Object-Relational Mapping) digunakan untuk memetakan data hubungan dalam pangkalan data kepada objek Java, menjadikannya lebih mudah untuk pembangun mengakses dan mengendalikan data. Spring Boot, sebagai salah satu rangka kerja pembangunan web Java yang paling popular pada masa ini, telah menyediakan cara untuk mengintegrasikan MyBatis, dan MyBatis Plus ialah rangka kerja ORM yang dilanjutkan berdasarkan MyBatis. Artikel ini akan memperkenalkan cara menggunakan Spring Boot dan MyBatis Plus untuk melaksanakan pemetaan ORM.

1. Spring Boot mengintegrasikan MyBatis Plus
Menggunakan MyBatis Plus dalam Spring Boot adalah sangat mudah, cuma tambahkan kebergantungan MyBatis Plus kepada maven.

<dependency>
  <groupId>com.baomidou</groupId>
  <artifactId>mybatis-plus-boot-starter</artifactId>
  <version>3.4.2</version>
</dependency>
Salin selepas log masuk

Pada masa yang sama, konfigurasikan parameter berkaitan MyBatis Plus dalam application.properties atau application.yml, seperti yang ditunjukkan di bawah:

#数据库配置
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
spring.datasource.url=jdbc:mysql://localhost:3306/mybatis_plus?useUnicode=true&characterEncoding=UTF-8&serverTimezone=UTC
spring.datasource.username=root
spring.datasource.password=123456
#MyBatis Plus配置
mybatis.configuration.cache-enabled=false
mybatis.mapper-locations=classpath:mapper/*.xml
Salin selepas log masuk

Antaranya, nama kelas pemandu, url, nama pengguna dan kata laluan ialah pangkalan data Konfigurasi berkaitan, dan lokasi pemeta ialah laluan di mana fail konfigurasi pemetaan SQL MyBatis Plus terletak.

2. Tentukan kelas entiti dan antara muka Mapper
Seperti MyBatis, menggunakan MyBatis Plus juga memerlukan penentuan kelas entiti dan antara muka Mapper. Berikut mengambil jadual Pengguna ringkas sebagai contoh untuk menentukan kelas entiti yang sepadan dan antara muka Mapper.

  1. Tentukan kelas entiti
@Getter
@Setter
@Builder
@NoArgsConstructor
@AllArgsConstructor
public class User {

    private Integer id;
    private String name;
    private Integer age;
    private String email;
    private Integer gender;
    private LocalDateTime createTime;
    private LocalDateTime updateTime;

}
Salin selepas log masuk

Menggunakan anotasi @Getter, @Setter dan @Builder boleh memudahkan kod, manakala @NoArgsConstructor dan @AllArgsConstructor digunakan untuk menjana tanpa parameter dan pembina Parameter penuh.

  1. Tentukan antara muka Mapper
public interface UserMapper extends BaseMapper<User> {
}
Salin selepas log masuk

BaseMapper yang disediakan oleh MyBatis Plus digunakan di sini, yang boleh menjimatkan banyak operasi SQL yang membosankan.

3. Gunakan MyBatis Plus untuk operasi pangkalan data
Selepas menentukan antara muka Mapper, anda boleh menggunakan MyBatis Plus untuk operasi pangkalan data.

  1. Sisipkan data
User user = User.builder()
        .name("test")
        .age(20)
        .email("test@test.com")
        .gender(1)
        .createTime(LocalDateTime.now())
        .updateTime(LocalDateTime.now())
        .build();
int count = userMapper.insert(user);
Salin selepas log masuk

Apabila memasukkan data, anda boleh terus menggunakan kaedah sisipan yang disediakan dalam antara muka Mapper dan MyBatis Plus akan memetakan atribut kelas entiti secara automatik ke lajur pangkalan data yang sepadan.

  1. Data pertanyaan
List<User> userList = userMapper.selectList(null);
Salin selepas log masuk

Apabila menanyakan data, anda boleh terus menggunakan kaedah selectList yang disediakan dalam antara muka Mapper dan menghantar objek kosong atau QueryWrapper kosong untuk menanyakan data Semua data. Selain itu, anda juga boleh menggunakan ungkapan lambda dan operasi rantai yang disediakan oleh MyBatis Plus untuk melaksanakan pertanyaan yang lebih kompleks, seperti yang ditunjukkan di bawah:

QueryWrapper<User> wrapper = Wrappers.<User>lambdaQuery()
        .eq(User::getGender, 1)
        .ge(User::getAge, 20)
        .orderByDesc(User::getCreateTime);
List<User> userList = userMapper.selectList(wrapper);
Salin selepas log masuk

Dalam kod di atas, gunakan Wrappers.lambdaQuery() A QueryWrapper objek ditakrifkan, dan syarat pertanyaan serta peraturan pengisihan dibina melalui operasi rantaian .eq, .ge dan .orderByDesc.

  1. Kemas kini data
User user = userMapper.selectById(id);
user.setAge(30);
int count = userMapper.updateById(user);
Salin selepas log masuk

Apabila mengemas kini data, anda boleh menanyakan data yang perlu dikemas kini dahulu melalui selectById, kemudian mengubah suai atribut yang perlu dikemas kini dan gunakan updateById untuk Data yang diubah suai dikemas kini kepada pangkalan data.

  1. Padam data
int count = userMapper.deleteById(id);
Salin selepas log masuk

Akhir sekali, apabila memadamkan data, panggil sahaja kaedah deleteById yang disediakan dalam antara muka Mapper.

4. Kesimpulan
Artikel ini memperkenalkan cara menggunakan Spring Boot dan MyBatis Plus untuk melaksanakan pemetaan ORM, dan operasi pangkalan data boleh dicapai melalui konfigurasi dan kod yang mudah. MyBatis Plus, sebagai rangka kerja lanjutan MyBatis, boleh memudahkan beban kerja pembangun sambil meningkatkan kebolehbacaan dan kebolehselenggaraan kod. Disebabkan oleh had ruang, artikel ini hanya memperkenalkan penggunaan asas MyBatis Plus Untuk fungsi yang lebih maju, sila rujuk dokumentasi rasmi.

Atas ialah kandungan terperinci Laksanakan pemetaan ORM berdasarkan Spring Boot dan MyBatis Plus. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan