位置: 编程技术 - 正文

实例测试MySQL的enum类型(mysql 测试)

编辑:rootadmin

推荐整理分享实例测试MySQL的enum类型(mysql 测试),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:mysql实验,mysql测试用例,mysql测试语句,mysql实验,mysql实验,mysql实验,mysql在软件测试中怎么运用,mysql测试用例,内容如对您有帮助,希望把文章链接给更多的朋友!

在开发项目时通常会遇到一些状态字段,例如订单的状态有 待支付、已支付、已关闭、已退款 等,我以前做的项目都是把这些状态用数字存在数据库中,然后在 php 代码中用常量来维护一份映射表,例如:

但是在实际使用过程中发现并不是那么好用,由于各种原因(追查 bug、临时的统计需求等)我们常常需要登录到 mysql 服务器里手动执行一些 sql 查询,由于许多表都有状态字段,写 sql 时必须对照的 php 代码里的映射关系来写,一不小心还有可能将不同表的状态数字弄混导致大问题。

于是我在新项目中准备使用 mysql 的 enum 类型来存储各种状态,在使用过程中发现如果在 Laravel 的 migration 文件中对使用了 enum 类型的表做变更(即使是变更非 enum 类型的字段)都会报错

搜索了一下,发现是 doctrine 不支持 mysql 的 enum,该文中列举了 enum 的 3 个缺点:

新增 enum 值的时候需要重建整个表,当数据量大的时候可能需要耗费数小时。

enum 值的排序规则是按创建表结构时指定的顺序,而非字面值的大小。

依赖 mysql 对 enum 值的校验并不是非常必要,在默认配置下插入非法值最终会变成空值。

根据新项目的实际情况,不太可能出现需要对状态字段做排序的需求,即使有我们可以在设计表结构的时候就定好顺序,因此缺点 2 可以忽略;而缺点 3 则可以通过代码规范、插入/更新前校验等方式来规避;至于缺点 1,我们需要做一些测试。

测试准备#

首先创建一个表:

然后插入 W 条数据:

测试过程#

测试1#

在 enum 值列表最后添加一个值 refunded

输出:

结论:在末尾追加 enum 值时几乎没有成本。

实例测试MySQL的enum类型(mysql 测试)

测试 2:#

删除刚刚添加的值 refunded

输出:

结论:删除一个没有用过的 enum 值仍需全表扫描,成本较高,但还在可接受范围内。

测试 3:#

将 refunded 插入到值列表中间而非末尾

输出:

结论:在原 enum 值列表中间新增值需要全表扫描并更新,成本较高。

测试 4:#

删除值列表中间的值

输出:

结论:需全表扫描,成本较高。

测试 5:#

给 status 字段添加索引后再执行上述测试

发现测试 2-4 的耗时反而有所增加,应该是同时需要更新索引导致的。

结语:#

对于我的新项目来说只会出现新增 enum 值的情况,即使将来有个别状态废弃不用也不需要去调整 enum 的值列表,因此决定在项目中引入 enum 类型作为存储状态的数据类型。

mysql5.7安装及配置教程 本文为大家分享了mysql安装配置教程,供大家参考,具体内容如下一、配置MySQL数据库1、解压绿色版mysql,并改名为mysql5.7,如下图对比一下下图5.6以前的

Mysql 8 新特性 window functions 的作用 MySQL8.0的新特性包括:对Unicode9.0的开箱即用的完整支持支持窗口函数和递归SQL语法,这在以往是不可能或者很难才能编写这样的查询语句对原生JSON数据

MYSQL如何自动为查询数据的结果编上序号详解 前言其实自己之前没遇到过这种在查询时给结果编号的情况,是同事打算跳槽,面试回来问到这种情况才想到去研究,以下以单表查询为例分析下:SQL

标签: mysql 测试

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

上一篇:MySQL 5.7.20绿色版安装详细图文教程(mysql8绿色版)

下一篇:mysql5.7安装及配置教程(mysql5.7.35安装配置教程)

  • 多缴纳社保怎么处理
  • 自己的医院
  • 税务是怎么回事
  • 开了发票不做收入的账务处理
  • 固定总价合同中,承包人承担的价格风险
  • 土地递减销售收益怎么算
  • 备用金三栏式明细账图片
  • 存货取得的分录
  • 分期收款销售会计分录(现销)
  • 预付房租的会计科目
  • 研发支出费用化支出每个月都要结转吗
  • 年内累计增量和年度增量计算公式
  • 餐饮业个体工商户怎么交税
  • 税号里的字母要大写还是小写
  • 企业弥补亏损的三个途径
  • 辅助生产成本科目月末有余额吗
  • 赞助贫困学生的语句
  • 资金使用计划表怎么写
  • 租用办公室协议书
  • 跨年度冲减收入
  • 免征增值税的税额还要交个人所得税吗
  • 在win7中,当前窗口的数量是多少个
  • window10的点在哪里
  • 天猫积分购物券怎么获得
  • jQuery+Ajax+PHP“喜欢”评级功能实现代码
  • 去年的发票忘记报销了 今年可以报销吗
  • 计提税金及附加的金额如何算
  • php数组函数题目
  • 挂账多年的往来账怎么处理
  • 应收票据包括哪些支票
  • wordpresswiki
  • php的工作流程
  • vue路由点击没反应
  • php null false
  • 应交增值税专栏下的增值税项目有哪些?
  • phpstudy访问数据库
  • vue3中props
  • 建筑企业分项目信息采集表怎么填
  • vue computed set get
  • 转正差额怎么算
  • 汇算清缴退税分录怎么写
  • 税控盘开票日期一般截止到下个月几号
  • 合伙企业的经营所得税率
  • 材料采购成本计算表
  • 光盘盒属于什么税收分类
  • 开一家公司的具体步骤
  • 记账凭证摘要的填制要求
  • 在异地施工就要在异地交税吗
  • 高铁行程信息提示可以乘车吗
  • 拆迁房视同销售成本可以抵减吗?
  • 报销人跟领款人有什么区别
  • 公司注销财务账本怎么处理
  • 其他应收款科目核算哪些业务
  • 长期股权投资的初始计量
  • 发票已开的情况下不确认收入可以吗?
  • execve函数
  • sql语言中delete删除命令语句详解
  • windowsxp关机没反应
  • XP从4月8日起将正式停止支持服务、升级到 Win 8.1图文教程
  • ubuntu14.04下apt-get install的报错以及解决方法
  • PHP startup: Unable to load dynamic library错误的错误
  • XP IIS5.1 + PHP 5.2.1 + MySQL 5.0.37 + Zend 3.2.6 + phpMyAdmin-2.10.0.2环境配置
  • shnlog.exe - shnlog是什么进程 有什么用
  • opengl画矩形函数
  • 贝塞尔曲线pr怎么用
  • javascript 数组操作
  • opengl glu
  • javascript scrollTop正解使用方法
  • Python分析学校四六级过关情况
  • vue数组里面添加数组
  • shell错误日志输出
  • 全屏沉浸式
  • 内容滑动切换效果怎么弄
  • 天津税务局怎么申报社保
  • 怎么查税务专管员是谁的名字
  • 对超市的建议和意见怎么写简短
  • 非税收入纳入一般公共预算管理
  • 煤炭行业的税负率是多少合适
  • 福建平潭综合实验区属于哪个市
  • e贷支付扣款管理是什么意思
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设