位置: 编程技术 - 正文

设置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)

  • 申报个人所得税在哪里报
  • 增值税结转会计科目
  • 城建税会计分录怎么写
  • 现金流量怎么影响股票价值
  • 申报更正日期改变会导致逾期申报吗
  • 土地置换账务处理流程
  • 增值税的核算方式
  • 职工食堂支出明细表
  • 暂估发票到账出入库单要填吗
  • 存款取款业务记入那个日记账?
  • 固定资产清理属于
  • 银行承兑汇票盖已承兑登记
  • 中意装饰工程有限公司怎么样
  • 增值税优惠的二级明细科目
  • 管理费用属于什么现金流量项目
  • 现金盘亏账务处理分录
  • 买一赠一怎么确定真假
  • 租用服务器会泄漏数据吗
  • 工资个人所得税标准表
  • 公司购买办公用品300元,以现金支付,购入后即被领用
  • 小型微利企业核定征收
  • 外汇汇兑损益怎么做账
  • 汽车4s店厂家返利计算方法
  • 如何查看电脑的型号和配置
  • 工商年报中生育保险本期实际缴费金额
  • 外经证预缴税款必须去外地交税吗
  • 给供应商垫付运费合法吗
  • 初级会计应收账款例题
  • PHP:session_module_name()的用法_Session函数
  • php和ajax用哪个调用数据
  • 错误申报多交增值税已经扣税
  • 领料单出库单区别
  • 企业财务管理内部控制问题与应对策略
  • 劳务报酬所得的计税标准
  • 低值易耗品报废时有残料价值收回的应冲减当月成本费用
  • /locate village村庄
  • 尚未进行抄报税无法申报是什么意思
  • 税务发票红字发票怎么开
  • 合伙股权退出机制
  • 公司购买绿植入什么科目
  • 酒店营业税率是多少
  • 结转成本计入
  • 城建税小规模纳税人
  • 月中入职算一个月吗
  • 企业存货按照经济内容可以分为
  • 收货和入库的区别
  • 公司销售不动产增值税
  • 公司股东分红要交税吗?
  • 专项应付款和政府补助的区别
  • 小额贷款公司ei
  • 保险公司 返点
  • 应交税费应交增值税进项税额在借方
  • 农场有多少只鸡
  • 原材料用于在建工程
  • 发票跨年红冲 交税
  • 开空头发票犯法吗
  • 小规模纳税人开专票税率是多少?
  • 单利率和复利率公式
  • 公司员工报销油费
  • 飞机发票和行程单一样吗
  • 提前还贷款要满十八岁吗
  • 公司初建账都有什么账
  • mysql found_row()使用详解
  • MySQL PXC构建一个新节点只需IST传输的方法(推荐)
  • window 启动
  • centos如何操作
  • linux如何设置用户自己的工作环境
  • 在linux操作系统中,/etc/rc.d/init.d
  • win7的语言栏不见了
  • windows10直接安装
  • MVC Ajax Helper或Jquery异步加载部分视图
  • css图片垂直居中对齐
  • 使用权资产
  • 在unity中单例的主要作用
  • android入门视频教程
  • 关于jquery的事件冒泡,以下描述正确的是
  • javascript异步编程
  • 上海市国家税务局地址
  • 不交社保申报个税有风险吗
  • 铁路检察院和普检哪个好
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设