位置: 编程技术 - 正文

设置MySQL中的数据类型来优化运行速度的实例(设置mysql数据库字符集的语句)

编辑:rootadmin

推荐整理分享设置MySQL中的数据类型来优化运行速度的实例(设置mysql数据库字符集的语句),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:mysql设置默认数据库语句,mysql 设置,mysql数据库怎么设置默认值,mysql设置enum,mysql设置enum,mysql 设置,mysql 设置,mysql 设置默认数值,内容如对您有帮助,希望把文章链接给更多的朋友!

今天看了一个优化案例觉的挺有代表性,这里记录下来做一个标记,来纪念一下随便的字段定义的问题。

回忆一下,在表的设计中很多人习惯的把表的结构设计成Varchar(),Varchar()之类的,虽然大多数情况只存了5-个字节.那么我看一下下面这个案例.查询语句:

该表(client_id,channel)是一个组合索引.利用explain,看一下执行计划,对于索引使用上看上非常完美

看一下实际执行:

设置MySQL中的数据类型来优化运行速度的实例(设置mysql数据库字符集的语句)

实际执行的情况非常的糟糕.传通的想法,这个执行从索引上执行计划上看非常完美了,好象和MySQL没什么关系了. 在去看一下表的设计会发现client_id也是设计成了varchar().看到这里不防可以使用下面的方法试一下:

从执行计划上来看,差不多,但实际差多了.具体上来看key_len从降到了,执行计划变成了const基于等于的查找,行数从原来千万级到了十万级了.不算也能明白IO节省了很多.再来看实际执行:

哇,从.秒变成了0.秒,这是什么概念,优化了多少倍,算一下吧.

看到这里在想什么呢,记住这个案例,嗯,不错,以后还可以加引号优化一下.那为什么不问一下,能不能在优化了,为什么会这样呢&#;我们先来看一下第一个问题:能不能在优化了&#;答案是当然可以了.从索引的长度上来看还是一个非常大的数据,对于client_id这个字段从名字上来看,也只会存数据型的值,那为什么不用的一个int unsigned去存呢,索引的长度马上会从降到4。这样不是又节省了很多吗?接下来看一下第二个问题,为什么会这样呢?原因有两点,同时基于一个原则,基于成本的优化器。对于client_id在表的定义时定义成了字符型的值,在查询时传入了数值型的值,需要经过一个数值转换,悲剧的开始,最终导致MySQL选择了一个完成的索引去扫描。

从这个案例上,我们需要注意什么呢?合理的选择数据类型,基本工太重要了,就这叫赢在起跑线,一切都不能随便了,别把一个表定义成了降了主建外其它全是Varchar()。对数据库的double/float这种字段做索引时一定要小心。

修改Innodb的数据页大小以优化MySQL的方法 我们知道Innodb的数据页是K,而且是一个硬性的规定,系统里没更改的办法,希望将来MySQL也能也Oracle一样支持多种数据页的大小。但实际应用中有时K

使用Perl DBI操作MySQL的一些建议 使用perl连接mysql,这个网上有很多案例了,一般大家都是DBI下的DBD::MySQL这个模块进行.这里做一个mask弄一个TIPS:PerlDBIMySQL的字符集为UTF8PerlDBI特殊字符

从MySQL的源码剖析Innodb buffer的命中率计算 按官方手册推荐InnodbbufferHitRatios的计算是:-((iReads/iReadRequests)*)iReads:mysql-status-Innodb_buffer_pool_readsiReadRequests:mysql-status-Innodb_buffer_pool_read_requests出处:htt

标签: 设置mysql数据库字符集的语句

本文链接地址:https://www.jiuchutong.com/biancheng/347352.html 转载请保留说明!

上一篇:MySQL中按时间获取慢日志信息的方法(mysql按时间查询)

下一篇:修改Innodb的数据页大小以优化MySQL的方法(innodb_sys_tables)

  • 生产企业出口退税的计算方法
  • 税率的具体形式
  • 销项税是什么意思进项税是什么意思
  • 视同销售但未收到钱怎么做账
  • 农业免税企业账户怎么查
  • 城市维护建设税税率
  • 饮料工业发展前景如何
  • 销售税金及附加含增值税吗
  • 收回以前年度的应收账款,怎么进行账务处理?
  • 普通发票发票联丢了
  • 法律规定临时工工资最迟多久结清
  • 文化事业建设费的征收范围
  • 金融企业三大使命是什么
  • 无票收入可以存钱吗
  • 企业收到税前投资分红如何缴纳增值税?
  • 回迁安置房拆一次多少钱
  • 工程物资期末余额应在资产负债表中填列?
  • 成本分摊会计
  • 多提的费用如何做冲减分录
  • 外汇账户怎么开
  • 上年结转的广告费次年怎么入账
  • 绿宝树的养殖方法和注意事项视频
  • php中的类是什么
  • 潘塔纳尔湿地的成因
  • 旅行社的会计
  • 个人所得税如何计算
  • PHP:imageellipse()的用法_GD库图像处理函数
  • yarn的配置
  • 含工资表的会计科目
  • 报销差旅费退回余款填什么凭证
  • 房地产开发企业分为几个等级
  • 其他综合收益需要写二级科目吗
  • java上传文件 multipartfile
  • rmt命令 远端磁带传输协议模块
  • 代销产品的形式有哪些
  • discuzq是个做什么
  • 工会经费减除项包括哪些
  • 一般纳税人无票收入怎么报增值税
  • 水果发票税率是几个点
  • python中map和filter有啥区别
  • MySQL中使用_____语句更新表中的数据
  • 织梦设置的关键词看不到
  • 个人所得税9月初申报哪个月的
  • 税务发票金额可以增加吗?
  • 进项税额不允许抵扣
  • 增值税专用设备是什么
  • 预收账款要预交税金吗
  • 应收账款增值税专用发票
  • 财务报销单据粘贴视频
  • 当月的增值税发票认证抵扣时间
  • 应收票据背书转让不终止确认如何记账
  • 应付职工薪酬如何进行会计处理
  • 厂房和设备折旧计入什么费用
  • 在mysql中,删除表的外键约束的关键字为()
  • fedora linux安装教程
  • win8更新到win8.1
  • openeuler操作系统安装方法
  • 电脑删除ie后怎么恢复
  • linux中locate命令的作用
  • win10 rs1是什么版本
  • propelac.exe - propelac是什么进程 有什么用
  • 苹果mac系统关机怎么关
  • win8系统忘记密码电脑重置
  • win10 window
  • Win10 RS1 14267 SDK版本发布下载
  • opengl 3d engine
  • nodejs的应用场景和优缺点
  • 用unity做2d游戏
  • jquery图片轮播无缝连接
  • 分享js粘帖屏幕怎么弄
  • linux哪些方法可以查看命令的详细信息
  • python做应用软件界面
  • python多线程菜鸟教程
  • python 自定义类模块
  • 云南税务查询系统
  • 2021税收分类编码大全
  • 夫妻双方房子契税怎么算
  • 建筑工程开票要在项目所在地
  • 上海疫情租房金额怎么算
  • 企业在开办过程中的具体流程
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设