MySQL字段值默认方式添加和非默认添加效率对比

测试内容

测试MySQL数据库字段采用默认方式存储值和非默认方式(通过MyBatis插入数据)的效率比较。

表结构

CREATE TABLE `student`  (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `name` varchar(255) CHARACTER SET gbk COLLATE gbk_chinese_ci NULL DEFAULT NULL,
  `address` varchar(255) CHARACTER SET gbk COLLATE gbk_chinese_ci NULL DEFAULT NULL,
  `age` int(11) NULL DEFAULT 0,
  `sex` int(1) NULL DEFAULT 0,
  PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 252001 CHARACTER SET = gbk COLLATE = gbk_chinese_ci ROW_FORMAT = Compact;

采用id自增的方式,防止插入过快造成的主键冲突。

测试代码

@Test
public void testInsert() {
    long utc1 = System.currentTimeMillis();
    for (int i = 0; i < 100000; i++){
        Student student = new Student("姓名","地址",i,0);
        customerDao.insertCustomer(student);
    }
    long utc2 = System.currentTimeMillis();
    System.out.println("==>"+(utc2-utc1));
}

采用时间戳的方式来判断运行时间的差别

POJO

public class Student {
    private Integer id;
    private String name;
    private String address;
    private Integer age;
    private Integer sex;

    public Student() {
    }

    public Student(String name, String address, Integer age, Integer sex) {
        this.name = name;
        this.address = address;
        this.age = age;
        this.sex = sex;
    }
}

对比【1】(除主键外所有字段均自定义插入)

插入100条数据(1713ms)

插入100条数据

插入1000条数据(3964ms)

插入1000条数据

插入10000条数据(19153ms)

插入10000条数据

插入50000条数据(84008ms)

插入50000条数据

插入100000条数据(277664ms)

插入100000

对比【2】('age’和’sex’字段使用数据库默认的方式)

插入100条数据(1731ms)

插入100条数据

插入1000条数据(3768ms)

插入1000条数据

插入10000条数据(19713ms)

插入10000条数据

插入50000条数据(86576ms)

插入50000条数据

插入100000条数据(298735ms)

插入100000条数据

结果

数量/条所用时间/ms(对比【1】)(对比【2】)
1001713 <==> 1731
10003964<==> 3768
1000019153<==> 19713
5000084008<==> 86576
100000277664<==> 298735

测试结果可能有误,有较多的不确定因素,建议亲自测试,以求达到数据更加真实。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值