在线精品99_中国九九盗摄偷拍偷看_91免费版在线观看_91.app_91高清视频在线_99热最新网站

MySQL中的大小写有区别吗

124次阅读
没有评论

共计 2398 个字符,预计需要花费 6 分钟才能阅读完成。

本篇内容介绍了“MySQL 中的大小写有区别吗”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让丸趣 TV 小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

如果根据关键字 case 来搜索,会发现有两个参数。

mysql show variables like %case%
+————————+——-+
| Variable_name  | Value |
+————————+——-+
| lower_case_file_system | OFF  |
| lower_case_table_names | 0  |
+————————+——-+
2 rows in set (0.01 sec)

  其中第一个参数是系统路径是否大小写敏感, 我们暂时跳过,看看第二个参数 lower_case_table_names,它的含义 0:区分大小写,1:不区分大小写。
  大小写的敏感问题,在 MySQL 大体会分为两种类别,在 Linux 和 Windows 平台。
MySQL 在 Linux 下数据库名、表名、列名、别名大小写规则是这样的:
1、数据库名与表名是严格区分大小写的;
2、表的别名是严格区分大小写的;
3、列名与列的别名在所有的情况下均是忽略大小写的;
4、变量名也是严格区分大小写的;

而 Windows 下的 MySQL 却是大小写不敏感的,所有表名和数据库名都会变成小写。
比如我们创建表 test_tab,然后插入两行记录,继续开启测试。

create table test_tab(id int,name varchar(64));
insert into test_tab values(1, aa),(2, bb

在默认的情况下,是开启了大小写敏感的,这样一来 test_tab,TEST_TAB 是完全不同的两个对象。

mysql select id,name from TEST_TAB;
ERROR 1146 (42S02): Table test.TEST_TAB doesn t exist
mysql
而在列级别,MySQL 是不区分大小写的。
mysql select id,NAMe from test_tab;
+——+———+
| id  | NAMe  |
+——+———+
|  1 | aa  |
|  2 | newtest |
+——+———+
2 rows in set (0.00 sec)
如果要修改大小写敏感的设置,比如设置为大小写不敏感,需要设置参数值,然后重启。

mysql set global lower_case_table_names=on;
ERROR 1238 (HY000): Variable lower_case_table_names is a read only variable

  重启后,test_TAB 和原来的 test_tab 就是一个意思了。
mysql desc test_TAB;
+——-+————-+——+—–+———+——-+
| Field | Type  | Null | Key | Default | Extra |
+——-+————-+——+—–+———+——-+
| id  | int(11)  | YES  |  | NULL  |  |
| name  | varchar(64) | YES  |  | NULL  |  |
+——-+————-+——+—–+———+——-+
2 rows in set (0.01 sec)
而如果在大小写敏感的情况下切换就很容易出现问题。

尤其需要注意这种兼容性的问题,如果对于存储过程等还存在疑虑,也可以开启测试模式。

delimiter //
drop procedure if exists `test_proc` //
create procedure test_proc(in push_id char(64))
begin
 update Test.test_tab set name= test where id=2;
end
//
delimiter ;

mysql call test_proc(newtest
Query OK, 1 row affected (0.00 sec)

mysql select *from test_tab;
+——+———+
| id  | name  |
+——+———+
|  1 | aa  |
|  2 | newtest |
+——+———+
2 rows in set (0.00 sec)
在这个地方还是要做详细的验收测试,务必已测试结果为准,因为大小写的问题出现了表数据不可访问就很不应该了。

另外额外提一下 Oracle 里面的大小写问题,Oracle 里面在 11g 有一个默认参数 sec_case_sensitive_logon,这个参数的实际应用真是有些悲剧,一来很多客户对这个特性并不喜欢,看似从安全的角度来调控,但似乎带来了更多的问题,有相当一部分是习惯使然,而另外一方面是因为这个参数在 11g 推出,在 12c 里面这个参数就过期了,含义也发生了变化,在使用中会有一些理解上的歧义。

  这个参数只能够保证登录用户密码的大小写敏感,其他还是和原来一样,12c 中这个参数变了味儿,在新版本中已经过期,在设置的时候务必需要保证 sqlnet.ora 中的设置需要兼容,文件中的参数 SQLNET.ALLOWED_LOGON_VERSION_SERVER 如果是 12,12a 就需要保证 SEC_CASE_SENSITIVE_LOGON 不为 false

“MySQL 中的大小写有区别吗”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注丸趣 TV 网站,丸趣 TV 小编将为大家输出更多高质量的实用文章!

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-08-01发表,共计2398字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)
主站蜘蛛池模板: 亚洲av无码一区二区三区牲色 | 一a级片| 国产精品久久久久久福利 | 国产成人午夜精华液 | 国产国语一级a毛片高清视频 | 久精品国产欧美亚洲色aⅴ大片 | 深夜视频福利 | 亚洲国产精品嫩草影院久久 | 国产亚洲女人久久久久久 | 桃色综合网 | 三级做爰视频三级 | 韩国19禁青草福利视频在线 | 九九99热久久国产 | 精品无码人妻夜人多侵犯18 | 国产男女猛烈无遮挡免费视频网站 | 色花堂国产精品原创第一页 | 国产欧美视频一区二区三区 | 中文字幕无线观看中文字幕 | 国产亚洲视频在线观看网址 | 一本大道熟女人妻中文字幕在线 | 精品无码人妻被多人侵犯av | 高清视频 一区二区三区四区 | wwwav在线| 久久久精品久久 | 欧美性大战久久久久xxx | 欧美v日本| 乱人伦中文字幕视频在线 | 97无码视频在线看视频 | 福利看片 | 国产一区二区三区亚洲欧美 | 99成人国产精品视频 | 韩国三级中文字幕hd | 日韩小视频在线 | 久久精品国产亚洲av高清色欲 | 两个人看的www免费高清 | avtt加勒比手机版天堂网 | 伊人久久大香线蕉综合网站 | 自拍偷拍欧美 | 福利片免费一区二区三区 | 中文字幕在线久热精品 | 又色又爽又高潮免费视频观看 |