跟我一起学习MySQL技术内幕(第五版):(第二章学习日记1)

第二章 使用SQL管理数据
2.1服务器的SQL模式
2.2MySQL的标识(zhi)符语法和命名规则
2.3SQL语句的大小写规则
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||

2.1

set sql_mode='tradition'

set global sql_mode='tradition'

select @@session.sql_mode;

select @@global.sql_mode;

SQL模式对SQL语句的执行会产生一定的影响。sql_mode可以用来配置这个模式,可以通过全局性的设置这个模式让其对所有的客户端都产生影响(语句一),也可以让每个客户端自己更改这个模式(语句二),从而只对自己的服务器会话产生影响。
如果想知道当前的的SQL模式值,可以通过第三四个语句返回当前会话或者全局的SQL模式值.

下面列出了几个可能的SQL模式值

select_all_tables 和strict_all_tables将启用严格模式。在严格模式下,MySQL将会更严格对待bad data(坏数据),拒绝接受而不再是转换为接近的有效值。

tradition是一个组合模式,通过启用其他模式,引入更多的附加限制条件。从而实现更加严格的数据检查。

ansi_quotes会告诉MySQL服务器把双引号识别为一个标示符引用字符。

pipes_as_concat会让服务器把‘||’当成一个标准的SQL字符串连接运算符,而不是or

ansi 是一个组合模式 会同时启用 ansi_quotes,pipes_as_concat和其他几个模式值

2.2
1.标识符里的字符要合法
注意两点 :MySQL支持标识符以数字字符开头的作法,但是如果要区分开事件和一个数字,就需要反引号将其包围起来,如果标识符是SQL保留字或者包含有空格或者其他字符,这时候需要引号来包围
2.服务器的SQL模式
如果使用了SQL的ansi_quotes模式,那么可以使用双引号将标识符引起来
如果使用了SQL的ignore_space模式函数名就会变成保留字,这时想要把他们当成标识符就要用引号把它们引起来。
3.标识符的长度
最大长度64个字符,别名256
4.标识符限定符
引用数据库,直接使用其名字

  use database_name;

 show tables from database_name;

引用表

show columns from database_name.table_name;

select   *   from database_name.table_name;

select   *   from table_name;

这三个句子都很好理解,其中三值得注意的是,这是在选择好后默认数据库(use database_name;)之后才能使用的,否则会报错。

所以当我们引用多个表时,要尽量以 table_name.column_name的格式,这样才不会引起重名或者其他的重大错误。

之后简单来说也可以在每一个部分加上引号

select * from 'sampdb '.'member' where 'sampdb'.'member'.'member_id'>100;

2.3
SQL语句的大小写规则
1.关键字和函数名不区分大小写。
2.数据库名,表名,视图名,windows系统的文件名是不区分大小写的。
3.存储程序的名字除了触发器都不需要区分大小写(我暂时也不知道触发器是啥,先记下了)
4.列名,引索名不区分大小写
5.别名的名字区分(如果lower_case_tabel_name系统变量为非零值,那么表的别名将不区分大小写)
6.字符串值
作者建议全部使用小写字母,Innob引擎在其内部都是以小写字母的方式来储存库名和表名的
如果想让系统自动统一的话,可以设置lower_case_table_name来设置

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值