문제:
min_value라는 두 개의 열이 있는 MySQL 테이블이 있습니다. 그리고 max_value. 이 두 값 사이에서 임의의 값을 검색하려고 합니다.
MySQL의 RAND() 함수는 이 기능을 직접 제공하지 않습니다. 가장 가까운 솔루션은 RAND() * (max-min) min이지만 정수가 아닌 부동 소수점을 생성합니다. 정수를 얻으려면 소수 부분을 자르는 ROUND()와 같은 다른 함수가 필요하지만 이는 비실용적입니다.
해결책:
가장 효율적인 방법 MySQL은 원래 표현식 ROUND((RAND() * (max-min)) min)을 사용합니다. 이는 ActionScript, JavaScript, Python과 같은 다른 프로그래밍 언어에서도 가장 좋은 접근 방식입니다.
PHP와 MySQL의 성능 비교:
확실하지 않은 경우 PHP 또는 MySQL에서 임의의 값을 생성할지 여부는 관련된 행 수를 고려하십시오. 데이터 세트가 큰 경우 MySQL을 사용하는 것이 더 효율적입니다.
성능 차이를 보여주기 위해 두 시나리오를 100,000회 반복으로 비교해 보겠습니다.
그러나 임의의 값과 함께 추가 열을 검색하면 PHP가 더 효율적이 됩니다.
결론적으로 최적의 성능을 위해서는 임의의 값만 필요한 경우에는 MySQL을 사용하고, 추가 열을 반환해야 하는 경우에는 PHP를 사용하는 것이 좋습니다.
위 내용은 다음은 질문 측면에 초점을 맞춘 몇 가지 제목 옵션입니다. 옵션 1(직접 및 일반): * MySQL의 범위 내에서 임의의 정수를 생성하는 방법은 무엇입니까? 옵션 2(문제 및 해결 방법에 집중): *의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!