Bagaimana SpringBoot memulakan dan memulakan pelaksanaan skrip sql
SpringBoot bermula dan memulakan pelaksanaan skrip sql
Bagaimana jika kita mahu melaksanakan beberapa skrip sql apabila projek bermula, SpringBoot menyediakan kita dengan ini fungsi, anda boleh melaksanakan skrip apabila memulakan projek SpringBoot Mari kita lihat.
Mari kita lihat kod sumber dahulu
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 |
|
Daripada kod sumber, secara kasar kita tahu maksudnya SpringBoot akan mencari fail skrip laluan kelas secara lalai, tetapi Hanya fail skrip dengan nama skema atau platform skema yang ditentukan boleh diletakkan di bawah laluan kelas Jika kita ingin membahagikan berbilang fail skrip, maka kaedah ini tidak sesuai, maka kita perlu menambahnya application.properties atau application.yml Pergi ke senarai skrip konfigurasi Bolehkah operasi skrip permulaan ini dikawal dalam fail konfigurasi Ya, terdapat atribut mod permulaan, yang boleh ditetapkan kepada tiga nilai sentiasa dilakukan , dan terbenam hanya memulakan pangkalan data memori (nilai lalai), seperti h3, dsb., tidak sekali-kali bermakna tiada permulaan dilakukan.
1 2 3 4 5 6 7 |
|
Mari sahkan dua kaedah ini di bawah
1 Letakkan fail skrip skema atau platform skema secara lalai
1 |
|
Lihat. Pangkalan data tidak mempunyai jadual jabatan. Seterusnya, kami memulakan program
Selepas memulakan, kami melihat sekali lagi dan melaksanakan
2. Tentukan berbilang skrip sql dalam fail konfigurasi
1 2 3 4 5 6 7 8 9 10 11 |
|
Tiga skrip sql ialah penyata sisipan
1 2 3 |
|
Tiada data dalam jadual sekarang. Seterusnya kita mulakan program
Selepas memulakannya, kita lihat semula dan terdapat tiga keping data dalam jadual
Ia adalah langkah untuk SpringBoot memulakan dan memulakan skrip sql
Projek SpringBoot melaksanakan fail sql yang ditentukan semasa permulaan
1 🎜>
Apabila projek dimulakan, laksanakan fail yang ditentukan dahulu Apabila anda memerlukan pernyataan SQL, anda boleh menambah fail SQL yang perlu dilaksanakan dalam folder sumber Pernyataan SQL dalam fail boleh menjadi skrip DDL atau DML skrip, dan kemudian tambahkan konfigurasi yang sepadan pada konfigurasi, seperti berikut:1 2 3 |
|
1 2 3 |
|
Buat folder untuk persekitaran yang berbeza
Buat folder yang sepadan dengan persekitaran berbeza dalam folder sumber, seperti dev/, sit/, prod/.Konfigurasi
application.yml1 2 3 4 |
|
1 2 3 |
|
1 2 3 4 5 |
|
5.1 Perangkap
Apabila terdapat prosedur atau fungsi yang disimpan dalam fail sql yang dilaksanakan, ralat akan dilaporkan semasa memulakan projek itu. Sebagai contoh, terdapat keperluan sekarang: apabila projek bermula, imbas jadual tertentu Apabila bilangan rekod dalam jadual ialah 0, masukkan berbilang rekod apabila lebih daripada 0, langkaunya. Skrip fail schema.sql adalah seperti berikut:1 2 3 4 5 6 |
|
Caused by: com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'create procedure p1() begin declare row_num int' at line 1
大致的意思是:'create procedure p1() begin declare row_num int'这一句出现语法错误。刚看到这一句,我一开始是懵逼的,吓得我赶紧去比对mysql存储过程的写法,对了好久都发现没错,最后看到一篇讲解spring boot配置启动时执行sql脚本的文章,发现其中多了一项配置:spring.datasource.separator=$$。然后看源码发现,spring boot在解析sql脚本时,默认是以';'作为断句的分隔符的。看到这里,不难看出报错的原因,即:spring boot把'create procedure p1() begin declare row_num int'当成是一条普通的sql语句。而我们需要的是创建一个存储过程。
5.2 解决方案
修改sql脚本的断句分隔符。如:spring.datasource.separator=$$。然后把脚本改成:
1 2 3 4 5 6 |
|
5.3 不足
因为sql脚本的断句分隔符从';'变成'$$',所以可能需要在DDL、DML语句的';'后加'$$',不然可能会出现将整个脚本当成一条sql语句来执行的情况。比如:
1 2 3 4 5 6 7 8 |
|
Atas ialah kandungan terperinci Bagaimana SpringBoot memulakan dan memulakan pelaksanaan skrip sql. 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

AI Hentai Generator
Menjana ai hentai secara percuma.

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

HQL dan SQL dibandingkan dalam rangka kerja Hibernate: HQL (1. Sintaks berorientasikan objek, 2. Pertanyaan bebas pangkalan data, 3. Keselamatan jenis), manakala SQL mengendalikan pangkalan data secara langsung (1. Piawaian bebas pangkalan data, 2. Boleh laku kompleks pertanyaan dan manipulasi data).

"Penggunaan Operasi Bahagian dalam OracleSQL" Dalam OracleSQL, operasi bahagi ialah salah satu operasi matematik yang biasa. Semasa pertanyaan dan pemprosesan data, operasi pembahagian boleh membantu kami mengira nisbah antara medan atau memperoleh hubungan logik antara nilai tertentu. Artikel ini akan memperkenalkan penggunaan operasi pembahagian dalam OracleSQL dan memberikan contoh kod khusus. 1. Dua cara operasi bahagi dalam OracleSQL Dalam OracleSQL, operasi bahagi boleh dilakukan dalam dua cara berbeza.

Oracle dan DB2 ialah dua sistem pengurusan pangkalan data hubungan yang biasa digunakan, setiap satunya mempunyai sintaks dan ciri SQL tersendiri. Artikel ini akan membandingkan dan membezakan antara sintaks SQL Oracle dan DB2, dan memberikan contoh kod khusus. Sambungan pangkalan data Dalam Oracle, gunakan pernyataan berikut untuk menyambung ke pangkalan data: CONNECTusername/password@database Dalam DB2, pernyataan untuk menyambung ke pangkalan data adalah seperti berikut: CONNECTTOdataba

Apakah Identity dalam SQL? Contoh kod khusus diperlukan Dalam SQL, Identity ialah jenis data khas yang digunakan untuk menjana nombor penambahan automatik. Ia sering digunakan untuk mengenal pasti setiap baris data dalam jadual. Lajur Identiti sering digunakan bersama dengan lajur kunci utama untuk memastikan setiap rekod mempunyai pengecam unik. Artikel ini akan memperincikan cara menggunakan Identiti dan beberapa contoh kod praktikal. Cara asas untuk menggunakan Identity ialah menggunakan Identit semasa membuat jadual.

Tafsiran teg SQL dinamik MyBatis: Penjelasan terperinci tentang penggunaan teg Set MyBatis ialah rangka kerja lapisan kegigihan yang sangat baik Ia menyediakan banyak teg SQL dinamik dan boleh membina pernyataan operasi pangkalan data secara fleksibel. Antaranya, tag Set ialah tag yang digunakan untuk menjana klausa SET dalam kenyataan UPDATE, yang sangat biasa digunakan dalam operasi kemas kini. Artikel ini akan menerangkan secara terperinci penggunaan teg Set dalam MyBatis dan menunjukkan kefungsiannya melalui contoh kod tertentu. Apakah itu Set tag Set tag digunakan dalam MyBati

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

Penyelesaian: 1. Semak sama ada pengguna log masuk mempunyai kebenaran yang mencukupi untuk mengakses atau mengendalikan pangkalan data, dan pastikan pengguna mempunyai kebenaran yang betul 2. Semak sama ada akaun perkhidmatan SQL Server mempunyai kebenaran untuk mengakses fail yang ditentukan atau folder, dan pastikan akaun Mempunyai kebenaran yang mencukupi untuk membaca dan menulis fail atau folder 3. Semak sama ada fail pangkalan data yang ditentukan telah dibuka atau dikunci oleh proses lain, cuba tutup atau lepaskan fail, dan jalankan semula pertanyaan 4 . Cuba sebagai pentadbir Jalankan Studio Pengurusan seperti dsb.

Bagaimana untuk menggunakan pernyataan SQL untuk pengagregatan data dan statistik dalam MySQL? Pengumpulan data dan statistik merupakan langkah yang sangat penting semasa melakukan analisis dan statistik data. Sebagai sistem pengurusan pangkalan data perhubungan yang berkuasa, MySQL menyediakan pelbagai fungsi pengagregatan dan statistik, yang boleh melaksanakan pengagregatan data dan operasi statistik dengan mudah. Artikel ini akan memperkenalkan kaedah menggunakan pernyataan SQL untuk melaksanakan pengagregatan data dan statistik dalam MySQL, dan menyediakan contoh kod khusus. 1. Gunakan fungsi COUNT untuk mengira Fungsi COUNT adalah yang paling biasa digunakan
