개발자 Q&A

개발하다 막혔다면? 여기서 질문하세요! 초보부터 고수까지, 함께 고민하고 해결하는 공간입니다. 누구나 자유롭게 질문하고 답변을 남겨보세요!

2025.03.08 19:25

mysqli::real_query 함수에 대한 질문

목록
  • 알고리즘장인 13일 전 2025.03.08 19:25
  • 9
    1
제가 php를 이용하여 MySQL 데이터베이스에 쿼리를 실행할 때 mysqli::real_query 함수를 사용하고 있습니다.
하지만, 이 함수를 사용했을 때 쿼리의 파라미터를 어떻게 설정해야 하는지 모르겠습니다.
예를 들어, 다음과 같은 쿼리를 실행할 때 parameter를 어떻게 설정해야 할까요?
php

$query = "SELECT * FROM users WHERE name = ? AND age = ?";

$result = mysqli::real_query($query, $param1, $param2);


위의 코드에서 $param1과 $param2는 어떻게 설정해야 하는지 알려주세요.

    댓글목록

    profile_image
    나우호스팅  13일 전



    mysqli::real_query 함수는 쿼리 실행 후 결과를 반환하는 함수입니다. 이 함수는 쿼리 파라미터를 받지 않기 때문에, 쿼리 내의 '?'를 직접 대체하여 쿼리를 실행해야 합니다.

    예를 들어, 다음과 같이 쿼리 파라미터를 직접 대체하여 쿼리를 실행할 수 있습니다.

    #hostingforum.kr
    php
    
    $query = "SELECT * FROM users WHERE name = 'John' AND age = 25";
    
    $result = mysqli_real_query($conn, $query);
    
    


    또는 쿼리 파라미터를 변수로 대체하여 쿼리를 실행할 수도 있습니다.

    #hostingforum.kr
    php
    
    $name = 'John';
    
    $age = 25;
    
    $query = "SELECT * FROM users WHERE name = '$name' AND age = $age";
    
    $result = mysqli_real_query($conn, $query);
    
    


    하지만, 위의 코드는 SQL 인젝션 공격에 취약합니다. 따라서 쿼리 파라미터를 직접 대체하는 방법이 더 안전합니다.

    mysqli::real_query 함수 대신에 mysqli_prepare 함수를 사용하는 것이 더 안전하고 효율적인 방법입니다. mysqli_prepare 함수는 쿼리 파라미터를 받을 수 있기 때문에, 쿼리 파라미터를 안전하게 대체할 수 있습니다.

    #hostingforum.kr
    php
    
    $stmt = $conn->prepare("SELECT * FROM users WHERE name = ? AND age = ?");
    
    $stmt->bind_param("si", $name, $age);
    
    $stmt->execute();
    
    $result = $stmt->get_result();
    
    


    위의 코드는 쿼리 파라미터를 안전하게 대체하여 쿼리를 실행합니다.

    2025-03-08 19:26

  • 개발자 Q&A 포인트 정책
      글쓰기
      50P
      댓글
      10P
  • 전체 5,323건 / 222 페이지

검색

게시물 검색