개발자 Q&A

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

2025.07.18 14:35

SwooleCoroutineMySQL::recv 사용법에 대한 질문

목록
  • Lambda마법사 1일 전 2025.07.18 14:35
  • 29
    1
제가 SwooleCoroutineMySQL::recv 함수를 사용하여 MySQL 데이터를 받아오는데, 다음과 같은 오류가 발생합니다.

php

$mysql = new SwooleCoroutineMySQL();

$mysql->connect('localhost', 3306, 'root', 'password');

$mysql->query('SELECT * FROM 테이블명');

$result = yield $mysql->recv();



위 코드는 실행되지만, 데이터가 제대로 받아오지 못하고, 빈 배열이 반환됩니다.

recv 함수의 사용법을 정확히 알고 싶습니다.

1. recv 함수는 query 함수를 호출한 후에 호출해야 하는 것인가요?
2. recv 함수는 query 함수를 호출한 후에 반드시 wait 함수를 호출해야 하는 것인가요?
3. recv 함수는 query 함수를 호출한 후에 반드시 fetch 함수를 호출해야 하는 것인가요?

위 질문에 대한 답변을 알려주시면 감사하겠습니다.

    댓글목록

    profile_image
    나우호스팅  1일 전



    SwooleCoroutineMySQL::recv 함수는 MySQL 데이터를 받아오는 데 사용됩니다.

    1. recv 함수는 query 함수를 호출한 후에 호출해야 합니다. query 함수를 호출하면 MySQL 쿼리가 실행되지만, 실제 데이터를 받아오려면 recv 함수를 호출해야 합니다.

    2. recv 함수는 반드시 wait 함수를 호출해야 합니다. wait 함수는 SwooleCoroutineMySQL 객체가 데이터를 받을 때까지 대기하도록 합니다.

    3. recv 함수는 반드시 fetch 함수를 호출해야 합니다. fetch 함수는 MySQL 쿼리의 결과를 받아와서 배열로 반환합니다.

    예를 들어, 다음과 같이 사용할 수 있습니다.

    #hostingforum.kr
    php
    
    $mysql = new SwooleCoroutineMySQL();
    
    $mysql->connect('localhost', 3306, 'root', 'password');
    
    $mysql->query('SELECT * FROM 테이블명');
    
    $mysql->wait(); // wait 함수를 호출하여 데이터를 받을 때까지 대기합니다.
    
    $result = yield $mysql->recv(); // recv 함수를 호출하여 데이터를 받아옵니다.
    
    


    위 코드는 MySQL 쿼리의 결과를 받아와서 $result 변수에 저장합니다.

    2025-07-18 14:36

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

검색

게시물 검색