位置: IT常识 - 正文

SQL代码编码原则和规范(sql代码大全)

编辑:rootadmin
SQL代码编码原则和规范

推荐整理分享SQL代码编码原则和规范(sql代码大全),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:sql代码是什么意思,sql编码格式,sql代码编码原则是什么,sql代码编码原则是什么,sql代码大全,sql代码是什么意思,sql代码编码原则是什么,sql 编码,内容如对您有帮助,希望把文章链接给更多的朋友!

目录专栏导读1、先了解MySQL的执行过程2、数据库常见规范3、所有表必须使用Innodb存储引擎4、每个Innodb表必须有个主键5、数据库和表的字符集统一使用UTF86、查询SQL尽量不要使用select *,而是具体字段7、避免在where子句中使用 or 来连接条件8、尽量使用数值替代字符串类型9、使用varchar代替char10、财务、银行相关的金额字段必须使用decimal类型11、避免使用ENUM类型12、去重distinct过滤字段要少13、where中使用默认值代替null14、避免在where子句中使用!=或<>操作符15、inner join 、left join、right join,优先使用inner join16、提高group by语句的效率17、清空表时优先使用truncate18、操作delete或者update语句,加个limit或者循环分批次删除19、UNION操作符20、SQL语句中IN包含的字段不宜过多21、批量插入性能提升22、表连接不宜太多,索引不宜太多,一般5个以内23、禁止给表中的每一列都建立单独的索引24、如何选择索引列的顺序25、对于频繁的查询优先考虑使用覆盖索引26、建议使用预编译语句进行数据库操作27、避免产生大事务操作28、避免在索引列上使用内置函数29、组合索引30、复合索引最左特性31、必要时可以使用force index来强制查询走某个索引32、优化like语句33、统一SQL语句的写法34、不要把SQL语句写得太复杂35、关于临时表36、将大的DELETE,UPDATE、INSERT 查询变成多个小查询37、使用explain分析你SQL执行计划38、读写分离与分库分表39、使用合理的分页方式以提高分页的效率40、尽量控制单表数据量的大小,建议控制在500万以内。41、谨慎使用Mysql分区表42、尽量做到冷热数据分离,减小表的宽度43、禁止在表中建立预留字段44、禁止在数据库中存储图片,文件等大的二进制数据45、建议把BLOB或是TEXT列分离到单独的扩展表中46、TEXT或BLOB类型只能使用前缀索引47、一些其它优化方式专栏导读

🏆作者简介:哪吒,CSDN2022博客之星Top1、CSDN2021博客之星Top2、多届新星计划导师✌、博客专家💪 ,专注Java硬核干货分享,立志做到Java赛道全网Top N。

🏆本文收录于Java基础教程系列(进阶篇),本专栏是针对大学生、初级Java工程师精心打造,针对Java生态,逐个击破,不断学习,打通Java技术栈。

🏆订阅后,可以阅读Java基础教程系列(进阶篇)中全部文章,包含Java基础、Java高并发、Spring、MySQL等Java进阶技术栈。

🏆还可以订阅其姐妹篇,Java基础教程系列,包含全部Java基础知识点、Java8新特性、Java集合、Java多线程、Java代码实例,理论结合实战,实现Java的轻松学习。

SQL代码编码原则和规范(sql代码大全)

🏆哪吒多年工作总结:Java学习路线总结,搬砖工逆袭Java架构师。

🏆面试福音:10万字208道Java经典面试题总结(附答案)

1、先了解MySQL的执行过程

了解了MySQL的执行过程,我们才知道如何进行sql优化。

客户端发送一条查询语句到服务器;服务器先查询缓存,如果命中缓存,则立即返回存储在缓存中的数据;未命中缓存后,MySQL通过关键字将SQL语句进行解析,并生成一颗对应的解析树,MySQL解析器将使用MySQL语法进行验证和解析。例如,验证是否使用了错误的关键字,或者关键字的使用是否正确;预处理是根据一些MySQL规则检查解析树是否合理,比如检查表和列是否存在,还会解析名字和别名,然后预处理器会验证权限;根据执行计划查询执行引擎,调用API接口调用存储引擎来查询数据;将结果返回客户端,并进行缓存;

2、数据库常见规范所有数据库对象名称必须使用小写字母并用下划线分割;所有数据库对象名称禁止使用mysql保留关键字;数据库对象的命名要能做到见名识意,并且最后不要超过32个字符;临时库表必须以tmp_为前缀并以日期为后缀,备份表必须以bak_为前缀并以日期(时间戳)为后缀;所有存储相同数据的列名和列类型必须一致;3、所有表必须使用Innodb存储引擎

没有特殊要求(即Innodb无法满足的功能如:列存储,存储空间数据等)的情况下,所有表必须使用Innodb存储引擎(mysql5.5之前默认使用Myisam,5.6以后默认的为Innodb)。

Innodb 支持事务,支持行级锁,更好的恢复性,高并发下性能更好。

4、每个Innodb表必须有个主键

Innodb是一种索引组织表:数据的存储的逻辑顺序和索引的顺序是相同的。每个表都可以有多个索引,但是表的存储顺序只能有一种。

Innodb是按照主键索引的顺序来组织表的

不要使用更新频繁的列作为主键,不适用多列主键;不要使用UUID、MD5、HASH、字符串列作为主键(无法保证数据的顺序增长);主键建议使用自增ID值;5、数据库和表的字符集统一使用UTF8

兼容性更好,统一字符集可以避免由于字符集转换产生的乱码,不同的字符集进行比较前需要进行转换会造成索引失效,如果数据库中有存储emoji表情的需要,字符集需要采用utf8mb4字符集。

6、查询SQL尽量不要使用select *,而是具体字段

select *的弊端:

增加很多不必要的消耗,比如CPU、IO、内存、网络带宽;增加了使用覆盖索引的可能性;增加了回表的可能性;当表结构发生变化时,前端也需要更改;查询效率低;7、避免在where子句中使用 or 来连接条件使用or可能会使索引失效,从而全表扫描;对于or没有索引的salary这种情况,假设它走了id的索引,但是走到salary查询条件时,它还得全表扫描;也就是说整个过程需要三步:全表扫描+索引扫描+合并。如果它一开始就走全表扫描,直接一遍扫描就搞定;虽然mysql是有优化器的,处于效率与成本考虑,遇到or条件,索引还是可能失效的;8、尽量使用数值替代字符串类型因为引擎在处理查询和连接时会逐个比较字符串中每一个字符;而对于数字型而言只需要比较一次就够了;字符会降低查询和连接的性能,并会增加存储开销;9、使用varchar代替charvarchar变长字段按数据内容实际长度存储,存储空间小,可以节省存储空间;char按
本文链接地址:https://www.jiuchutong.com/zhishi/294517.html 转载请保留说明!

上一篇:Echarts地图的基本使用方法(echarts地图参数设置)

下一篇:Vue3的vue-router超详细使用(vue–router)

  • 怎样重装系统win10保留原文件(怎样重装系统win7)(怎样重装系统win7系统旗舰版)

    怎样重装系统win10保留原文件(怎样重装系统win7)(怎样重装系统win7系统旗舰版)

  • imovie有安卓版的吗(安卓版imovie2019)

    imovie有安卓版的吗(安卓版imovie2019)

  • vivos7和vivox50的区别有哪些(vivos7和vivix50哪个好)

    vivos7和vivox50的区别有哪些(vivos7和vivix50哪个好)

  • opporeno4手机是双卡双待吗(oppo reno4是不是双模)

    opporeno4手机是双卡双待吗(oppo reno4是不是双模)

  • 在qq里怎么看黑名单里的人(怎么看qq里面的黑名单)

    在qq里怎么看黑名单里的人(怎么看qq里面的黑名单)

  • 苹果封面的手电筒为什么点不了(苹果封面的手电筒和相机怎么打开)

    苹果封面的手电筒为什么点不了(苹果封面的手电筒和相机怎么打开)

  • 学习通可以切屏吗

    学习通可以切屏吗

  • 荣耀play4tpro刷新率(荣耀play4tpro刷新率修改器)

    荣耀play4tpro刷新率(荣耀play4tpro刷新率修改器)

  • 苹果手机电池烫手怎么回事(苹果手机电池烫的把屏幕)

    苹果手机电池烫手怎么回事(苹果手机电池烫的把屏幕)

  • 电池寿命91需要换吗(电池寿命91需要充电吗)

    电池寿命91需要换吗(电池寿命91需要充电吗)

  • 为什么知乎加载不出来(为什么知乎加载的图片是黑白色的)

    为什么知乎加载不出来(为什么知乎加载的图片是黑白色的)

  • 中央处理器的作用(中央处理器作为计算机)

    中央处理器的作用(中央处理器作为计算机)

  • mate30pro不小心掉水里咋办(华为mate30pro掉地上)

    mate30pro不小心掉水里咋办(华为mate30pro掉地上)

  • iphone7可以换字体吗(iphone 7如何换字体)

    iphone7可以换字体吗(iphone 7如何换字体)

  • 电脑启动不能进入系统(电脑启动不能进入桌面)

    电脑启动不能进入系统(电脑启动不能进入桌面)

  • mate30pro音量键怎么按(mate30e pro音量键)

    mate30pro音量键怎么按(mate30e pro音量键)

  • ios13闪光灯怎么开启(苹果ios13闪光灯怎么开)

    ios13闪光灯怎么开启(苹果ios13闪光灯怎么开)

  • qq其他应用打开怎么改(qq其他应用打开怎么重新设置)

    qq其他应用打开怎么改(qq其他应用打开怎么重新设置)

  • 云闪付可以扫微信吗(云闪付)

    云闪付可以扫微信吗(云闪付)

  • 抖音怎么发声控类视频(在抖音上怎么弄声控)

    抖音怎么发声控类视频(在抖音上怎么弄声控)

  • iphone6内置应用如何恢复(苹果手机6自带软件)

    iphone6内置应用如何恢复(苹果手机6自带软件)

  • 苹果的itunes在哪里(iphone的itunes store在哪)

    苹果的itunes在哪里(iphone的itunes store在哪)

  • x27通话录音在哪里(x27手机电话录音在哪)

    x27通话录音在哪里(x27手机电话录音在哪)

  • 百度视频如何找课程(百度视频如何找原创)

    百度视频如何找课程(百度视频如何找原创)

  • 苹果x能分屏吗(苹果x可以分屏的吗)

    苹果x能分屏吗(苹果x可以分屏的吗)

  • WebSocket开发(心跳监测)功能(websocket())

    WebSocket开发(心跳监测)功能(websocket())

  • esxcfg-firewall命令  防火墙设置(firewall enable)

    esxcfg-firewall命令 防火墙设置(firewall enable)

  • 电脑学习网教大家2022年最新WordPress官方微信支付接口设置傻瓜设置教程-OK源码教学(网上学电脑哪个软件好)

    电脑学习网教大家2022年最新WordPress官方微信支付接口设置傻瓜设置教程-OK源码教学(网上学电脑哪个软件好)

  • 小规模销售收入要做销项税额吗
  • 一般风险准备是留存收益吗
  • 有形动产租赁服务属于现代服务吗
  • 反结账只能反结上月的账吗
  • 进项抵扣的金额怎么算
  • 知道含税价,税率,怎么算税金
  • 票面3个点的增值税发票是交几个点的税金
  • 经营利润和营业利润的区别
  • 未分配利润太多说明什么
  • 特殊销售方式的计税依据
  • 社会保险的登记和申报程序
  • 如何填写增值税及附加税费申报表
  • 银行手续费是否一定要开发票吗
  • 发票章丢失风险大吗
  • 股权转让印花税是双方都要缴纳吗
  • 哪些人可以享受长护险
  • 小规模纳税人是公司还是个人
  • 劳动生产总值计算公式.doc
  • 发票的开具时效为
  • 固定资产投资增值税进项税额抵扣规定
  • 总分机构异地移送
  • 发票跨期审计调查报告
  • 对公账户被诈骗转款728000会怎么样呢
  • 公司认缴出资怎么交税
  • 商誉准则最新修订时间
  • 公允价值变动损益借贷方向增减
  • 金税三期系统的对比有哪几个
  • github ci/cd
  • 瑞吉外卖项目简历
  • 经典动画动漫
  • js怎样遍历对象中的每个元素
  • Android AsyncTack 异步任务实例详解
  • 主营业务成本记错了怎么调整
  • 预提跨年工资怎么处理
  • python怎么用
  • 其他业务收入与营业外收入
  • 现金发放工资会计科目怎么写
  • sqlserver2008数据库备份和恢复步骤
  • 带薪休假工资怎么扣税的
  • 公司与公司的往来款计入什么科目
  • 外币报表折算差额可以转损益吗
  • 个体户也需要纳税吗
  • 房产增值税发票可以抵税吗
  • 债务转化为资本是啥意思?
  • 财付通支付的优缺点
  • 劳务报酬所得怎么做分录
  • 应交增值税的结转怎么算
  • 机关单位工会经费提取比例
  • 停产工人工资计入哪个科目
  • 期末贷方余额什么意思
  • 保修的产品还收费吗
  • 外购设备的会计分录
  • 公司返聘退休人员的员工比例有没有规定
  • 陪标收费标准
  • 销售货物没开票是不是不交税
  • 如何调整银行存款余额
  • 购买软件会计科目
  • 简易征收是什么意思和一般纳税人
  • 运费是属于什么会计科目
  • 如何设计高效合理的未来课程
  • mysql5.7解压版安装
  • win7隐藏共享文件夹
  • win7系统IE浏览器一点就闪退
  • xp系统在新建账户怎么弄
  • centos named
  • linux安全性从何而来
  • linux的内存
  • win10系统右键菜单管理
  • win10系统免费升级
  • win8个性化外观恢复默认设置
  • linux we
  • opengl矩形
  • cocos2d怎么用
  • javascript教程
  • javascript的主要内容
  • 西安经开税务局电话号码
  • 如何证明发货前货物完好
  • 徐州市哪些区域封闭了
  • 一般纳税人附加税减半征收政策
  • 沙石开发票
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设