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