码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 六.schema设计


    文章目录

      • 一.库表的设计范式
      • 二.选择更优的数据类型
        • 1.原则
        • 2.字段类型
      • 三.设计陷阱

    一.库表的设计范式

    • 第一范式:表中的任何字段不可拆分
    • 第二范式:表中的非主属性都要完全依赖于主键
    • 第三范式:满足第二范式的基础上,表中的非主属性不能相互依赖

    二.选择更优的数据类型

    1.原则

    • 更小的通常更好,前提是存储范围不被低估
    • 简单为好,简单数据类型处理起来更高效
    • 避免存储NULL,可以为NULL的列使得索引、索引统计和值都比较复杂

    2.字段类型

    • 整型

      • tinyint:8
      • mediumint:16
      • int:32
      • bigint:64
      • unsingned修饰:范围扩大一倍

      int(1)和int(32) 的存储和计算是相同的,只是长度只是规定了交互工具展示的位数

    • 实数类型

      • 浮点运算
        • float:32位
        • double:64位
      • 精确计算:decimal
    • 字符类型

      • varchar:可变字符串,需要1~2位存储长度,适用场景:
        • 最大长度远大于最小长度
        • 列的更新很少
        • 适用了复杂的字符集,每个字符的字节数不同
      • char:固定长度字符串,未完全填充时使用空格,适用场景:
        • 非常短的字符串,无需而外存储长度
        • 所有字符串长度几乎相同
        • 经常修改的数据,比varchar好,不容易出现碎片
      • 大文本类型
        • blob:二进制,没有排序规则和字符集
        • text:有排序规则和字符集
      • 枚举类型:存储更为紧凑,同时会将值存为整数
      • 日期和时间类型
        • datetime:1000~9999,精度微秒
        • timestamp:1970年1月1日以来的秒数,依赖于时区(服务器、操作系统、客户端均可设置),插入和更新时会默认更新第一列timestamp值为当前时间
      • 压缩位数据类型bit,二进制而非数字类型
      • json数据类型,需要存储额外的字符,占用空间更大

    三.设计陷阱

    • 避免太多列,服务器和存储引擎之间通过行复制进行工作,服务器将行解码为列,列过多时解码的CPU消耗较高
    • 避免太多连接:连接过多时会成为并发的瓶颈
    • NULL不是虚拟值,可以使用0、特殊字符、空字符串进行代替
  • 相关阅读:
    使用VirtualBox安装Ubuntu系统【保姆级】
    webpack打包js文件
    onehot-词嵌入-图嵌入
    鸿蒙开发 p60 pro手机支持 api9吗
    base64转为file
    23种设计模式(二十一)备忘录模式(阁瑞钛伦特软件-九耶实训)
    【FAQ】华为健康数据唤起授权后出现 907135702错误
    js 数组根据某个字段去重
    CSS(四)盒子模型+圆角边框+盒子阴影+文字阴影
    asp毕业设计——基于asp+sqlserver的工厂设备管理系统设计与实现(毕业论文+程序源码)——工厂设备管理系统
  • 原文地址:https://blog.csdn.net/qq_43216019/article/details/133722320
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号