MYSQL使用实战基础操作

sql是一门语言,因此包含函数(包含内置函数)、逻辑控制等等,这些东西是一个积累的过程,不是一篇文章可以介绍完的。本文介绍一些常用的基础规范,记录开发过程中用到的

  • 子查询位置: select、 from、where、后面
  • sql执行顺序
select                                   7

distinct查询列表                          8

from 表1                                 1
【join type】 表2                         2

on 连接条件                               3

where 筛选条件                            4

group by 分组条件                         5

hanving 分组后筛选条件                     6
order by 排序条件                          9

limit【offset】,size                       10

备注: offset—起始索引值(0开始);size:每页行数

from--> join ---> on -->where -->group by --> avg sum --->having---> select ---> distinct -->

order by –> limit

  • 数据类型

1. 如果整形数据没有负数,如ID号,建议指定为UNSIGNED无符号类型,容量可以扩大一倍。
2. 建议使用TINYINT代替ENUM、BITENUM、SET。
3. 避免使用整数的显示宽度(参看文档最后),也就是说,不要用INT(10)类似的方法指定字段显示宽度,直接用
INT。
4. DECIMAL最适合保存准确度要求高,而且用于计算的数据,比如价格。但是在使用DECIMAL类型的时候,注意
长度设置。

  • 日期和时间

1. MySQL能存储的最小时间粒度为秒。
2. 建议用DATE数据类型来保存日期。MySQL中默认的日期格式是yyyy-mm-dd。
3. 用MySQL的内建类型DATE、TIME、DATETIME来存储时间,而不是使用字符串。
4. 当数据格式为TIMESTAMP和DATETIME时,可以用CURRENT_TIMESTAMP作为默认(MySQL5.6以后),
MySQL会自动返回记录插入的确切时间。
5. TIMESTAMP是UTC时间戳,与时区相关。
6. DATETIME的存储格式是一个YYYYMMDD HH:MM:SS的整数,与时区无关,你存了什么,读出来就是什么。
7. 除非有特殊需求,一般的公司建议使用TIMESTAMP,它比DATETIME更节约空间,但是像阿里这样的公司一般会用DATETIME,因为不用考虑TIMESTAMP将来的时间上限问题。
8. 有时人们把Unix的时间戳保存为整数值,但是这通常没有任何好处,这种格式处理起来不太方便,我们并不推荐
它。

索引命名规范

  1. int类型创建的时候需要写长度吗? 类似于 `id` INT(2) UNSIGNED ZEROFILL  ---不会影响数据的插入,只会在使用ZEROFILL时有用,让查询结果前填充0。UNSIGNED ---

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值