Laravel menyokong pertanyaan SQL asli, tetapi mengikat parameter harus lebih disukai untuk memastikan keselamatan; 1. Gunakan db :: pilih () untuk melaksanakan pertanyaan pilih dengan parameter mengikat untuk mencegah suntikan SQL; 2. Gunakan db :: kemas kini () untuk melaksanakan operasi kemas kini dan mengembalikan bilangan baris yang terjejas; 3. Gunakan db :: masukkan () untuk memasukkan data; 4. Gunakan db :: padam () untuk memadam data; 5. Gunakan db :: pernyataan () untuk melaksanakan pernyataan SQL tanpa set keputusan seperti membuat, mengubah, dan sebagainya; 6. Adalah disyorkan untuk menggunakan Whereraw, SelectRaw dan kaedah lain dalam pembina pertanyaan untuk menggabungkan ekspresi asli untuk meningkatkan keselamatan; 7. Elakkan menggunakan db :: tidak bersedia () untuk memproses input pengguna, dan ia hanya digunakan untuk operasi dalaman yang dipercayai. Ringkasnya, SQL asli tersedia, tetapi keselamatan mesti dijamin melalui pengikatan parameter dan kaedah pelanjutan pembina pertanyaan yang lebih selamat lebih disukai.
Di Laravel, sementara Orm fasih dan pembina pertanyaan biasanya digunakan, ada kalanya anda perlu menulis pertanyaan SQL mentah untuk operasi kompleks atau pengoptimuman prestasi. Laravel menyediakan beberapa cara untuk melaksanakan SQL mentah dengan selamat dan berkesan.

Berikut adalah contoh praktikal menggunakan SQL mentah di Laravel:
? Menggunakan DB::select()
untuk pertanyaan pilih mentah
Gunakan Illuminate \ support \ facades \ db; $ pengguna = db :: pilih ('pilih * dari pengguna di mana umur>?', [18]);
- Parameter pertama ialah SQL mentah.
- Yang kedua adalah pelbagai pengikatan (untuk mengelakkan suntikan SQL).
- Mengembalikan pelbagai objek
stdClass
.
? Nota: Sentiasa gunakan parameter mengikat (
[18]
) dan bukannya menggabungkan pembolehubah secara langsung.
? Menggunakan DB::update()
untuk pertanyaan kemas kini mentah
$ terjejas = db :: kemas kini ('Kemas kini pengguna menetapkan undi =? Where name =?', [100, 'John']);
- Mengembalikan bilangan baris yang terjejas.
? Menggunakan DB::insert()
untuk pertanyaan sisipan mentah
Db :: masukkan ('masukkan ke pengguna (nama, e -mel, umur) nilai (?,?)', [[ 'Jane Doe', 'jane@example.com', 25 ]);
? Menggunakan DB::delete()
untuk pertanyaan padam mentah
$ dipadam = db :: padam ('Padam dari pengguna di mana umur <?', [18]);
? Menggunakan DB::statement()
untuk skema atau pertanyaan yang tidak dipilih
Gunakan ini untuk SQL mentah yang tidak mengembalikan hasil (misalnya, CREATE
, ALTER
, DROP
):
Db :: pernyataan ('Buat jadual jika tidak ada temp_users (id int auto_increment utama utama, nama varchar (255))');
? Menggunakan Ekspresi Mentah dalam Pembina Pertanyaan (Alternatif yang lebih selamat)
Daripada pertanyaan mentah penuh, anda boleh menyuntik ungkapan mentah di mana diperlukan:

$ users = db :: Table ('Pengguna') -> whereraw ('umur>? dan status =?', [18, 'aktif']) -> selectRaw ('id, nama, dikemas kini, (umur * 2) sebagai doubled_age') -> mendapatkan ();
Atau pesanan dengan ungkapan mentah:
-> orderByraw ('Nama ASC, created_at desc')
? Menggunakan DB::unprepared()
(tidak disyorkan)
Ini menjalankan SQL mentah tanpa mengikat - berbahaya jika input pengguna terlibat .
Db :: tidak bersedia ('drop meja pengguna_backup');
?? Hanya gunakan untuk operasi dalaman yang dipercayai (misalnya, migrasi, skrip persediaan).
Ringkasan Kaedah Biasa
Kaedah | Gunakan kes |
---|---|
DB::select()
|
RAW PILIH PERTAMA |
DB::update()
|
Pertanyaan kemas kini mentah |
DB::insert()
|
Pertanyaan memasukkan mentah |
DB::delete()
|
RAW DELETE PERTAMA |
DB::statement()
|
Skema atau pertanyaan DDL |
DB::unprepared()
|
Tidak selamat - Elakkan dengan input dinamik |
Sekiranya anda bekerja di dalam model yang fasih atau memerlukan lebih banyak fleksibiliti, pertimbangkan untuk menggunakan ekspresi mentah ( whereRaw
, selectRaw
, dll.) Daripada pertanyaan mentah penuh - mereka lebih selamat dan mengintegrasikan dengan lebih baik dengan ekosistem Laravel.
Pada asasnya, SQL mentah disokong, tetapi sentiasa mengutamakan parameter mengikat dan mengelakkan unprepared
dengan data pengguna.
Atas ialah kandungan terperinci Contoh pertanyaan SQL Raw Laravel. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undress AI Tool
Gambar buka pakaian secara percuma

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

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

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

UsearestapitobridgePhpandMlmodelsbyrunningthemodelinpythonviaflaskorfastapiandcallingitfromphpusingcurlorguzzle.2.runpythonsc riptsdirectlyFromphpusingExec () ortshell_exec () forsimple, trafficusecases rendah, walaupunThisapproachhassecurityandperformancelimitat

Laravel menyokong penggunaan pertanyaan SQL asli, tetapi parameter mengikat harus lebih disukai untuk memastikan keselamatan; 1. Gunakan db :: pilih () untuk melaksanakan pertanyaan pilih dengan parameter mengikat untuk mencegah suntikan SQL; 2. Gunakan db :: kemas kini () untuk melaksanakan operasi kemas kini dan mengembalikan bilangan baris yang terjejas; 3. Gunakan db :: masukkan () untuk memasukkan data; 4. Gunakan db :: padam () untuk memadam data; 5. Gunakan db :: pernyataan () untuk melaksanakan pernyataan SQL tanpa set keputusan seperti membuat, mengubah, dan sebagainya; 6. Adalah disyorkan untuk menggunakan Whereraw, SelectRaw dan kaedah lain dalam QueryBuilder untuk menggabungkan ungkapan asli untuk meningkatkan keselamatan

Pengaturcaraan responsif melaksanakan kesesuaian yang tinggi, perkhidmatan yang tidak menyekat latensi rendah di Java melalui ProjectReactor dan SpringWebFlux. 1. ProjectReactor menyediakan dua jenis teras: mono dan fluks, menyokong pemprosesan deklaratif aliran data tak segerak, dan penukar, penapis dan operasi lain melalui rantai pengendali; 2. SpringWebFlux dibina di atas reaktor, menyokong dua model pengaturcaraan: anotasi dan berfungsi. Ia berjalan pada pelayan yang tidak menyekat seperti Netty, dan dengan cekap dapat mengendalikan sejumlah besar sambungan serentak; 3. Menggunakan Reaktor WebFlux boleh meningkatkan keupayaan konkurensi dan penggunaan sumber dalam senario I/O-intensif, dan secara semulajadi menyokong SSE dan WebSO.

JWT adalah standard terbuka untuk penghantaran maklumat yang selamat. Di Java, pengesahan dan kebenaran dapat dicapai melalui Perpustakaan JJWT. 1. Tambah JJWT API, Impl dan Jackson Dependencies; 2. Buat kelas alat JWTutil untuk menjana, menghuraikan dan mengesahkan token; 3. Tulis JWtfilter memintas permintaan dan sahkan Bearertokens dalam pengepala kebenaran; 4. Daftar penapis dalam springboot untuk melindungi laluan yang ditentukan; 5. Menyediakan antara muka log masuk untuk mengembalikan JWT selepas mengesahkan pengguna; 6. Antara muka yang dilindungi memperoleh identiti dan peranan pengguna melalui menguraikan token untuk kawalan akses, dan akhirnya menyedari mekanisme keselamatan yang tidak bertenaga dan extensible, sesuai untuk sistem yang diedarkan.

Go Generik disokong sejak 1.18 dan digunakan untuk menulis kod generik untuk jenis selamat. 1. Fungsi generik printslice [tany] (s [] t) boleh mencetak kepingan mana -mana jenis, seperti [] int atau [] rentetan. 2. Melalui had bilangan kekangan jenis t ke jenis angka seperti int dan float, jumlah [tnumber] (slice [] t) t Summation selamat direalisasikan. 3. Struktur generik Typebox [Tany] struct {valuet} boleh merangkum sebarang nilai jenis dan digunakan dengan pembina kotak baru [Tany] (Vt)*. 4. Tambahkan set (vt) dan dapatkan () kaedah t untuk kotak [t] tanpa

Layout Jadual: Tetap akan memaksa lebar lajur jadual ditentukan oleh lebar sel baris pertama untuk mengelakkan kandungan yang mempengaruhi susun atur. 1. Tetapkan jadual-Layout: Tetapkan dan tentukan lebar jadual; 2. Tetapkan nisbah lebar lajur tertentu untuk baris pertama th/td; 3. Gunakan ruang putih: nowrap, limpahan: tersembunyi dan teks-overflow: ellipsis untuk mengawal limpahan teks; 4. Berkenaan dengan pengurusan latar belakang, laporan data dan senario lain yang memerlukan susun atur yang stabil dan rendering berprestasi tinggi, yang secara efektif dapat menghalang susun atur susun atur dan meningkatkan kecekapan rendering.

Gunakan Junit5 dan Mockito untuk mengasingkan kebergantungan secara berkesan untuk ujian unit. 1. Buat objek mengejek melalui @mock, @Injectmocks menyuntik contoh yang diuji, @extendwith membolehkan lanjutan Mockito; 2. Gunakan bila (). KemudianReturn () untuk menentukan tingkah laku simulasi, sahkan () untuk mengesahkan bilangan panggilan dan parameter; 3. Boleh mensimulasikan senario pengecualian dan mengesahkan pengendalian ralat; 4. Mengesyorkan suntikan pembina, elakkan daripada simulasi, dan mengekalkan atom ujian; 5. Gunakan assertAll () untuk menggabungkan pernyataan, dan @nested menganjurkan senario ujian untuk meningkatkan penguraikan ujian dan kebolehpercayaan.

ChoosetheapproprateindextypebasedOnusecase, suchassinglefield, compound, multikey, text, geospatial, orttlindexes.2.aplytheesrrulewhencreatinginginginDexesbyorderingfieldsasequaly, sort, thenrange
