Pertanyaan Berparameter SQL: Rahsia Tanda Tanya
Apabila membaca buku SQL, anda mungkin perasan bahawa tanda soal (?) sering digunakan dalam pertanyaan. Tanda soal ini memainkan peranan penting dalam pertanyaan berparameter, yang digunakan secara meluas untuk pelaksanaan SQL dinamik dalam atur cara.
Pertanyaan berparameter elakkan menggunakan pertanyaan rentetan ringkas secara langsung, yang meningkatkan keselamatan dan menghalang kelemahan suntikan SQL. Mereka bertindak sebagai pemegang tempat dan diberi nilai secara dinamik apabila pertanyaan dilaksanakan.
Pertimbangkan contoh berikut:
<code>ODBCCommand cmd = new ODBCCommand("SELECT thingA FROM tableA WHERE thingB = ?") cmd.Parameters.Add(7) result = cmd.Execute()</code>
Di sini, tanda soal (?) bertindak sebagai pemegang tempat untuk nilai dinamik 7, yang diberikan kepada parameter 'thingB'. Kaedah ini melindungi sistem daripada input berniat jahat yang boleh mengeksploitasi kelemahan keselamatan.
Sebagai contoh, jika pengguna memasukkan input hasad berikut:
<code>Robert'); DROP TABLE students; --</code>
Apabila menggunakan pertanyaan berparameter, perpustakaan akan membersihkan input, dan hasilnya ialah:
<code>"SELECT * FROM students WHERE name = 'Robert''); DROP TABLE students; --'"</code>
Berkesan menghalang penyerang daripada melaksanakan niat jahat mereka.
Sesetengah sistem pengurusan pangkalan data (DBMS), seperti MS SQL, menggunakan parameter bernama, meningkatkan kebolehbacaan dan kejelasan. Contohnya:
<code>cmd.Text = "SELECT thingA FROM tableA WHERE thingB = @varname" cmd.Parameters.AddWithValue("@varname", 7) result = cmd.Execute()</code>
Dengan menggunakan pertanyaan berparameter dengan tanda soal atau menggunakan parameter bernama dalam sesetengah DBMS, anda boleh melindungi pangkalan data anda daripada serangan suntikan dan mengekalkan integriti data anda.
Atas ialah kandungan terperinci Bagaimanakah Pertanyaan Berparameter Menggunakan Tanda Soalan Menghalang Suntikan SQL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!