Mysql大小写敏感的问题 --转
一、1 CREATE TABLE NAME(name VARCHAR(10));
??? ??? 對這個表,缺省情況下,下面兩個查詢的結(jié)果是一樣的:
?? ???? SELECT * FROM TABLE NAME WHERE name='clip';
??? ??? SELECT * FROM TABLE NAME WHERE name='Clip';
??? ??? MySql默認查詢是不區(qū)分大小寫的,如果需要區(qū)分他,必須在建表的時候,Binary標示敏感的屬性.
??? ??? CREATE TABLE NAME(
?? ?? ??? name VARCHAR(10) BINARY
??? ??? );
?????? 2 在SQL語句中實現(xiàn) SELECT * FROM TABLE NAME WHERE? BINARY name='Clip';
3 設(shè)置字符集:
utf8_general_ci --不區(qū)分大小寫
utf8_bin--區(qū)分大小寫
二、 MySQL在windows下是不區(qū)分大小寫的,將script文件導(dǎo)入MySQL后表名也會自動轉(zhuǎn)化為小寫,結(jié)果再 想要將數(shù)據(jù)庫導(dǎo)出放到linux服務(wù)器中使用時就出錯了。因為在linux下表名區(qū)分大小寫而找不到表,查了很多都是說在linux下更改MySQL的設(shè)置使其也不區(qū)分大小寫,但是有沒有辦法反過來讓windows 下大小寫敏感呢。其實方法是一樣的,相應(yīng)的更改windows中MySQL的設(shè)置就行了。
??? ??? 具體操作:
??? ??? 在MySQL的配置文件my.ini中增加一行:
??? ??? lower_case_table_names = 0
??? ??? 其中 0:區(qū)分大小寫,1:不區(qū)分大小寫
??? ??? MySQL在Linux下數(shù)據(jù)庫名、表名、列名、別名大小寫規(guī)則是這樣的:
??? 1、數(shù)據(jù)庫名與表名是嚴格區(qū)分大小寫的;
??? 2、表的別名是嚴格區(qū)分大小寫的;
??? 3、列名與列的別名在所有的情況下均是忽略大小寫的;
??? 4、變量名也是嚴格區(qū)分大小寫的;??? MySQL在Windows下都不區(qū)分大小寫
原文:http://blog.163.com/shanpeng921@126/blog/static/30463279200861010513820/
轉(zhuǎn)載于:https://www.cnblogs.com/davidwang456/p/3955695.html
《新程序員》:云原生和全面數(shù)字化實踐50位技術(shù)專家共同創(chuàng)作,文字、視頻、音頻交互閱讀總結(jié)
以上是生活随笔為你收集整理的Mysql大小写敏感的问题 --转的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: MySql中把一个表的数据插入到另一个表
- 下一篇: mysql中判断字段为空