Cara menggunakan JPA sebagai rangka kerja kegigihan data dalam SpringBoot
JPA ialah singkatan Java Persistence API Nama Cina ialah Java Persistence Layer API Ia adalah hubungan pemetaan antara anotasi JDK 5.0 atau objek penerangan XML dan jadual hubungan, dan mengekalkan objek entiti pada masa jalan ke dalam pangkalan data.
1. Memperkenalkan kebergantungan
<!-- spring mvc --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <!-- mysql 驱动 --> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <scope>runtime</scope> </dependency> <!-- lombok --> <dependency> <groupId>org.projectlombok</groupId> <artifactId>lombok</artifactId> </dependency> <!-- jpa持久层 --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-jpa</artifactId> </dependency>
2. Konfigurasi sambungan pangkalan data
server: port: 8080 spring: datasource: url: jdbc:mysql://127.0.0.1:3306/jpa-demo?useUnicode=true&useJDBCCompliantTimezoneShift=true&useLegacyDatetimeCode=false&serverTimezone=Asia/Shanghai&useSSL=true&characterEncoding=UTF-8 driver-class-name: com.mysql.cj.jdbc.Driver username: root password: 123456 jpa: hibernate: # 自动创建表 ddl-auto: update
ddl-auto mempunyai jumlah lima nilai pilihan
tiada: Buat apa-apa
buat: Setiap kali hibernate dimuatkan, jadual yang dijana terakhir akan dipadamkan dan kemudian jadual baharu akan dijana berdasarkan kelas model anda, walaupun ia adalah dua kali Ini dilakukan walaupun tiada perubahan Ini adalah sebab penting untuk kehilangan data jadual pangkalan data.
create-drop: Jadual dijana berdasarkan kelas model setiap kali hibernate dimuatkan, tetapi jadual dipadamkan secara automatik sebaik sahaja sessionFactory ditutup.
kemas kini: Atribut yang paling biasa digunakan Apabila hibernate dimuatkan buat kali pertama, struktur jadual akan ditubuhkan secara automatik berdasarkan kelas model (dengan syarat pangkalan data diwujudkan dahulu) . Apabila hibernate dimuatkan kemudian, ia akan berdasarkan kelas model Kelas secara automatik mengemas kini struktur jadual Walaupun struktur jadual berubah tetapi baris dalam jadual masih wujud, baris sebelumnya tidak akan dipadamkan. Perlu diingatkan bahawa apabila digunakan ke pelayan, struktur jadual tidak akan ditubuhkan serta-merta, tetapi akan menunggu sehingga aplikasi dijalankan buat kali pertama.
sah: Setiap kali hibernate dimuatkan, ia mengesahkan struktur jadual pangkalan data yang dibuat Ia hanya akan membandingkannya dengan jadual dalam pangkalan data, dan tidak akan mencipta jadual baharu, tetapi akan masukkan nilai baru.
3. Objek data (DO)
import lombok.Data; import javax.persistence.*; @Table(name = "sys_user") @Entity @Data public class SysUserDO { /** * 主键-自增 */ @Id @GeneratedValue(strategy = GenerationType.IDENTITY) private Long id; @Column(columnDefinition = "varchar(12) comment '用户名称'") private String name; @Column(columnDefinition = "varchar(50) comment '邮箱'") private String email; }
@Id, menunjukkan bahawa atribut ini ialah medan kunci utama
-
@GeneratedValue(strategy = GenerationType.IDENTITY), menggunakan kaedah auto-kenaikan kunci utama
@Column, menentukan atribut medan pangkalan data, anda boleh menetapkan jenis data, panjang, ulasan dan maklumat lain, anda juga boleh menulis anotasi, jpa secara automatik akan mengenali
4. Objek kegigihan
import com.biz.jpa.entity.SysUserDO; import org.springframework.data.jpa.repository.JpaRepository; import org.springframework.stereotype.Repository; @Repository public interface SysUserRepository extends JpaRepository<SysUserDO, Long> { }
@Repositori, menunjukkan bahawa ini ialah lapisan akses data
5 Lapisan perniagaan
import com.biz.jpa.dao.SysUserRepository; import com.biz.jpa.entity.SysUserDO; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; @Service public class SysUserService { @Autowired private SysUserRepository sysUserRepository; public SysUserDO saveUser() { SysUserDO sysUser = new SysUserDO(); sysUser.setName("Asurplus"); sysUser.setEmail("123456@qq.com"); sysUserRepository.save(sysUser); return sysUser; } }
Kami memasukkan sekeping data ke dalam jadual pengguna_sys Memandangkan kunci utama ditambah secara automatik, kami tidak perlu menetapkannya kunci utama. Selepas pemasukan berjaya, kunci utama yang ditambah secara automatik akan ditulis semula ke objek
6 Ujian
import com.biz.jpa.entity.SysUserDO; import com.biz.jpa.service.SysUserService; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.RestController; @RestController public class SysUserController { @Autowired private SysUserService sysUserService; @GetMapping("save") public SysUserDO save() { return sysUserService.saveUser(); } }
Akses:
http://localhost:8080/save
.
Pulangan:
{"id":1,"name":"Asurplus","email":"123456@qq.com"}
Pemasukan telah berjaya dan kunci utama yang ditambah secara automatik telah dikembalikan, Jpa Penyepaduan selesai di sini Lebih banyak penggunaan Jpa perlu diterokai dalam pembangunan projek sebenar.
Atas ialah kandungan terperinci Cara menggunakan JPA sebagai rangka kerja kegigihan data dalam SpringBoot. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

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

Video Face Swap
Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas











Pengenalan kepada Jasypt Jasypt ialah perpustakaan java yang membenarkan pembangun menambah fungsi penyulitan asas pada projeknya dengan usaha yang minimum dan tidak memerlukan pemahaman yang mendalam tentang cara penyulitan berfungsi dengan tinggi untuk penyulitan sehala dan dua hala. teknologi penyulitan berasaskan piawai. Sulitkan kata laluan, teks, nombor, perduaan... Sesuai untuk penyepaduan ke dalam aplikasi berasaskan Spring, API terbuka, untuk digunakan dengan mana-mana pembekal JCE... Tambahkan kebergantungan berikut: com.github.ulisesbocchiojasypt-spring-boot-starter2 Faedah Jasypt melindungi keselamatan sistem kami Walaupun kod itu bocor, sumber data boleh dijamin.

Memilih JPA atau MyBatis bergantung pada keperluan dan keutamaan tertentu. Kedua-dua JPA dan MyBatis ialah rangka kerja lapisan kegigihan Java, dan kedua-duanya menyediakan fungsi memetakan objek Java ke jadual pangkalan data. Jika anda memerlukan rangka kerja matang yang menyokong operasi merentas pangkalan data, atau projek itu telah menggunakan JPA sebagai penyelesaian lapisan kegigihan, terus menggunakan JPA mungkin merupakan pilihan yang lebih baik. Jika anda mahukan prestasi yang lebih tinggi dan keupayaan penulisan SQL yang lebih fleksibel, atau sedang mencari penyelesaian yang kurang bergantung pada pangkalan data, MyBatis adalah lebih sesuai.

JPA dan MyBatis: Analisis Perbandingan Fungsi dan Prestasi Pengenalan: Dalam pembangunan Java, rangka kerja kegigihan memainkan peranan yang sangat penting. Rangka kerja kegigihan biasa termasuk JPA (JavaPersistenceAPI) dan MyBatis. Artikel ini akan menjalankan analisis perbandingan fungsi dan prestasi kedua-dua rangka kerja dan menyediakan contoh kod khusus. 1. Perbandingan fungsi: JPA: JPA ialah sebahagian daripada JavaEE dan menyediakan penyelesaian kegigihan data berorientasikan objek. Ia diluluskan anotasi atau X

1. Redis melaksanakan prinsip kunci teragih dan mengapa kunci teragih diperlukan Sebelum bercakap tentang kunci teragih, adalah perlu untuk menjelaskan mengapa kunci teragih diperlukan. Lawan daripada kunci yang diedarkan ialah kunci yang berdiri sendiri Apabila kami menulis program berbilang benang, kami mengelakkan masalah data yang disebabkan oleh mengendalikan pembolehubah yang dikongsi pada masa yang sama Kami biasanya menggunakan kunci untuk mengecualikan pembolehubah yang dikongsi bersama untuk memastikan ketepatannya pembolehubah yang dikongsi skop penggunaannya adalah dalam proses yang sama. Jika terdapat berbilang proses yang perlu mengendalikan sumber yang dikongsi pada masa yang sama, bagaimanakah ia boleh saling eksklusif? Aplikasi perniagaan hari ini biasanya merupakan seni bina perkhidmatan mikro, yang juga bermakna bahawa satu aplikasi akan menggunakan berbilang proses Jika berbilang proses perlu mengubah suai baris rekod yang sama dalam MySQL, untuk mengelakkan data kotor yang disebabkan oleh operasi yang tidak teratur, keperluan pengedaran. untuk diperkenalkan pada masa ini. Gaya dikunci. Ingin mencapai mata

Springboot membaca fail, tetapi tidak boleh mengakses perkembangan terkini selepas membungkusnya ke dalam pakej balang Terdapat situasi di mana springboot tidak boleh membaca fail selepas membungkusnya ke dalam pakej balang adalah tidak sah dan hanya boleh diakses melalui strim. Fail berada di bawah resources publicvoidtest(){Listnames=newArrayList();InputStreamReaderread=null;try{ClassPathResourceresource=newClassPathResource("name.txt");Input

Apabila Springboot+Mybatis-plus tidak menggunakan pernyataan SQL untuk melaksanakan operasi penambahan berbilang jadual, masalah yang saya hadapi akan terurai dengan mensimulasikan pemikiran dalam persekitaran ujian: Cipta objek BrandDTO dengan parameter untuk mensimulasikan parameter yang dihantar ke latar belakang bahawa adalah amat sukar untuk melaksanakan operasi berbilang jadual dalam Mybatis-plus Jika anda tidak menggunakan alatan seperti Mybatis-plus-join, anda hanya boleh mengkonfigurasi fail Mapper.xml yang sepadan dan mengkonfigurasi ResultMap yang berbau dan kemudian. tulis pernyataan sql yang sepadan Walaupun kaedah ini kelihatan menyusahkan, ia sangat fleksibel dan membolehkan kita

SpringBoot dan SpringMVC adalah kedua-dua rangka kerja yang biasa digunakan dalam pembangunan Java, tetapi terdapat beberapa perbezaan yang jelas antara mereka. Artikel ini akan meneroka ciri dan penggunaan kedua-dua rangka kerja ini dan membandingkan perbezaannya. Mula-mula, mari belajar tentang SpringBoot. SpringBoot telah dibangunkan oleh pasukan Pivotal untuk memudahkan penciptaan dan penggunaan aplikasi berdasarkan rangka kerja Spring. Ia menyediakan cara yang pantas dan ringan untuk membina bersendirian, boleh dilaksanakan

1. Sesuaikan RedisTemplate1.1, mekanisme siri lalai RedisAPI Pelaksanaan cache Redis berasaskan API menggunakan templat RedisTemplate untuk operasi cache data Di sini, buka kelas RedisTemplate dan lihat maklumat kod sumber kelas tersebut. Isytihar kunci, Pelbagai kaedah pesirilan nilai, nilai awal kosong @NullableprivateRedisSe
