Laksanakan pemetaan ORM berdasarkan Spring Boot dan MyBatis Plus
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>
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
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.
- 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; }
Menggunakan anotasi @Getter, @Setter dan @Builder boleh memudahkan kod, manakala @NoArgsConstructor dan @AllArgsConstructor digunakan untuk menjana tanpa parameter dan pembina Parameter penuh.
- Tentukan antara muka Mapper
public interface UserMapper extends BaseMapper<User> { }
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.
- 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);
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.
- Data pertanyaan
List<User> userList = userMapper.selectList(null);
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);
Dalam kod di atas, gunakan Wrappers.
- Kemas kini data
User user = userMapper.selectById(id); user.setAge(30); int count = userMapper.updateById(user);
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.
- Padam data
int count = userMapper.deleteById(id);
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!

Artikel ini membincangkan menggunakan Maven dan Gradle untuk Pengurusan Projek Java, membina automasi, dan resolusi pergantungan, membandingkan pendekatan dan strategi pengoptimuman mereka.

Artikel ini membincangkan membuat dan menggunakan perpustakaan Java tersuai (fail balang) dengan pengurusan versi dan pergantungan yang betul, menggunakan alat seperti Maven dan Gradle.

Artikel ini membincangkan pelaksanaan caching pelbagai peringkat di Java menggunakan kafein dan cache jambu untuk meningkatkan prestasi aplikasi. Ia meliputi persediaan, integrasi, dan faedah prestasi, bersama -sama dengan Pengurusan Dasar Konfigurasi dan Pengusiran PRA Terbaik

Artikel ini membincangkan menggunakan JPA untuk pemetaan objek-relasi dengan ciri-ciri canggih seperti caching dan pemuatan malas. Ia meliputi persediaan, pemetaan entiti, dan amalan terbaik untuk mengoptimumkan prestasi sambil menonjolkan potensi perangkap. [159 aksara]

Kelas kelas Java melibatkan pemuatan, menghubungkan, dan memulakan kelas menggunakan sistem hierarki dengan bootstrap, lanjutan, dan pemuat kelas aplikasi. Model delegasi induk memastikan kelas teras dimuatkan dahulu, yang mempengaruhi LOA kelas tersuai


Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Dreamweaver Mac版
Alat pembangunan web visual

PhpStorm versi Mac
Alat pembangunan bersepadu PHP profesional terkini (2018.2.1).

SublimeText3 versi Inggeris
Disyorkan: Versi Win, menyokong gesaan kod!

DVWA
Damn Vulnerable Web App (DVWA) ialah aplikasi web PHP/MySQL yang sangat terdedah. Matlamat utamanya adalah untuk menjadi bantuan bagi profesional keselamatan untuk menguji kemahiran dan alatan mereka dalam persekitaran undang-undang, untuk membantu pembangun web lebih memahami proses mengamankan aplikasi web, dan untuk membantu guru/pelajar mengajar/belajar dalam persekitaran bilik darjah Aplikasi web keselamatan. Matlamat DVWA adalah untuk mempraktikkan beberapa kelemahan web yang paling biasa melalui antara muka yang mudah dan mudah, dengan pelbagai tahap kesukaran. Sila ambil perhatian bahawa perisian ini

mPDF
mPDF ialah perpustakaan PHP yang boleh menjana fail PDF daripada HTML yang dikodkan UTF-8. Pengarang asal, Ian Back, menulis mPDF untuk mengeluarkan fail PDF "dengan cepat" dari tapak webnya dan mengendalikan bahasa yang berbeza. Ia lebih perlahan dan menghasilkan fail yang lebih besar apabila menggunakan fon Unicode daripada skrip asal seperti HTML2FPDF, tetapi menyokong gaya CSS dsb. dan mempunyai banyak peningkatan. Menyokong hampir semua bahasa, termasuk RTL (Arab dan Ibrani) dan CJK (Cina, Jepun dan Korea). Menyokong elemen peringkat blok bersarang (seperti P, DIV),