Mysql
 sql >> Cơ Sở Dữ Liệu >  >> RDS >> Mysql

Tôi có phải sử dụng mysql_real_escape_string nếu tôi ràng buộc các tham số không?

Không, bạn không phải tự mình thoát khỏi giá trị (tức là không, bạn không cần gọi mysqli_real_escape_string ) , khi bạn đang sử dụng các câu lệnh đã chuẩn bị sẵn:công cụ DB sẽ tự thực hiện điều đó.

(Trên thực tế, nếu bạn đang gọi mysql_real_escape_string và sử dụng các tham số bị ràng buộc, các chuỗi của bạn sẽ bị thoát hai lần - điều này sẽ không tuyệt vời:bạn sẽ kết thúc với việc thoát các ký tự ở khắp mọi nơi ...)


Dưới dạng ghi chú bên cạnh:các giá trị của bạn được chuyển dưới dạng số nguyên (như được chỉ ra bởi 'ii' ) , vì vậy bạn sẽ không phải gọi mysql_real_escape_string , ngay cả khi bạn không sử dụng các câu lệnh đã chuẩn bị sẵn:như tên gọi của nó chỉ ra, hàm này được sử dụng để thoát ... chuỗi.

Đối với số nguyên, tôi thường chỉ sử dụng intval để đảm bảo dữ liệu tôi đưa vào các truy vấn SQL của mình thực sự là số nguyên.

(Tuy nhiên, khi bạn đang sử dụng các truy vấn đã chuẩn bị sẵn, một lần nữa, bạn không cần phải tự thoát ra như vậy)



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Nó được phát âm là “S-Q-L” hay “Phần tiếp theo”?

  2. Điền các biểu mẫu html với dữ liệu mysql bằng php sắp tới là null

  3. Kết nối MATLAB và MySQL với Trình điều khiển JDBC

  4. Sửa chữa tất cả các bảng trong một lần

  5. Làm thế nào để nhân bản bảng trong MySQL