>데이터 베이스 >MySQL 튜토리얼 >SQL에서 공백 변형을 무시하고 사용자 이름을 검색하려면 어떻게 해야 합니까?

SQL에서 공백 변형을 무시하고 사용자 이름을 검색하려면 어떻게 해야 합니까?

Patricia Arquette
Patricia Arquette원래의
2024-12-24 00:30:30683검색

How Can I Search for Usernames Ignoring Whitespace Variations in SQL?

공백 변화에도 불구하고 사용자 이름 검색

사용자 이름을 검색할 때 필드의 공백을 무시하는 것이 바람직한 경우가 많습니다. 예를 들어, 사용자가 "JohnBobJones", "John Bob Jones" 및 "JohnBobJones"인 데이터베이스에서 "John Bob Jones"를 검색하면 세 항목이 모두 검색될 것이라고 예상하는 것이 합리적입니다.

공백 정규화를 사용한 SQL 쿼리

이 공백에 구애받지 않는 검색을 수행하려면 다음 SQL 쿼리를 사용할 수 있습니다. 사용:

SELECT * FROM mytable 
    WHERE REPLACE(username, ' ', '') = REPLACE("John Bob Jones", ' ', '')

이 쿼리는 REPLACE() 함수를 사용하여 사용자 이름 필드와 검색 문자열 모두에서 모든 공백 문자를 제거합니다. 정규화된 값을 비교함으로써 공백 유무가 검색 결과에 영향을 주지 않는지 확인합니다.

PHP 또는 Python으로 구현

SQL 쿼리는 다음과 같습니다. 적절한 데이터베이스 커넥터를 사용하여 PHP 또는 Python에서 실행됩니다. 다음은 PHP 예입니다.

$db = new mysqli('localhost', 'user', 'password', 'database');
$stmt = $db->prepare("SELECT * FROM mytable 
    WHERE REPLACE(username, ' ', '') = REPLACE('John Bob Jones', ' ', '')");
$stmt->execute();
$result = $stmt->get_result();

Python 예:

import mysql.connector

db = mysql.connector.connect(
    host='localhost',
    user='user',
    password='password',
    database='database'
)

cursor = db.cursor()
cursor.execute("SELECT * FROM mytable 
    WHERE REPLACE(username, ' ', '') = REPLACE('John Bob Jones', ' ', '')")
result = cursor.fetchall()

이러한 코드 조각은 데이터베이스 연결을 설정하고 정규화된 값으로 SQL 쿼리를 실행하며 일치하는 항목을 검색합니다. .

위 내용은 SQL에서 공백 변형을 무시하고 사용자 이름을 검색하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.