문제

On my MySQL database, my collation is set to utf8_general_ci. I also checked the collation of table in my database. This should allow for case insensitive queries. However all queries are still are still case sensitive.

For example, this query will not work if I have the username with the first letter capitalized.

  SELECT * 
  FROM   users 
  WHERE  username = 'test' 
  AND    password = 'test' 

I am using MySQL 5.5.27 Community edition. Thanks.

도움이 되었습니까?

해결책

Your collation set to ci (case-insensitive) only affects the way you search in data, not columns. IIRC, column names are case sensitive and table names aren't.

Follow a standard naming convention for your database.

다른 팁

I don't know too much about databases set to be case insensitive, but you can use Lower()

eg:

SELECT * FROM users WHERE Lower(username) = 'test' AND lower(password) = 'test'

Follow the @mauris answer. Otherwise you use strtolower($username) in php and

SELECT * FROM users WHERE LOWER(username) = 'test' AND password = 'test'
라이센스 : CC-BY-SA ~와 함께 속성
제휴하지 않습니다 StackOverflow
scroll top