首页 数据库 mysql教程 Oracle 的 char number varchar2 效率测试

Oracle 的 char number varchar2 效率测试

Jun 07, 2016 pm 05:33 PM
or

Oracle 的 char number varchar2 效率测试

自己在建表的时候,用到了编号的这个字段,

主要问题是要用java连接数据库,所以要有pojo类,

就像 编号 这种字段,int 不够,long 转起来麻烦,还容易出错。

突然想看看char可不可以,所以就稀里糊涂的想看看,这几种数据类型的查找效率究竟如何。

--首先总要先建立一张表吧(如果有重复的话,先删掉...)
drop table yard_test;
create table yard_test (
  yrd_id char(32),
  yrd_num number,
  yrd_var varchar2(32),
  into_time date,
  yrd_txt varchar2(4000)
);

--必然要有需要的数据类型 char number varchar2

--下面可以插入数据了,建一个plsql语句块,执行一下就可以。
declare
  v_temp yard_test%rowtype;
  v_begin_time timestamp := systimestamp;
  v_end_time timestamp;
  v_all_time timestamp;
begin
for i in 1..100 loop
  --每一万条数据提交一次,总共提交100万次,其实有点多,我都没耐性等他插入完成就......
  for j in 1..10000 loop
    v_temp.yrd_id := sys_guid();
    v_temp.yrd_var := sys_guid();
    select nvl(max(yrd_num),0)+1 into v_temp.yrd_num from yard_test;
    --本来应该用sequence的,嫌麻烦,,直接用select语句取得max值+1 得到了序号...
    v_temp.yrd_txt := substr(sys_guid(),1,1);
    insert into yard_test values(
    v_temp.yrd_id,
    v_temp.yrd_num,
    v_temp.yrd_var,
    systimestamp,
    v_temp.yrd_txt);
    v_end_time := systimestamp;
    v_all_time := v_all_time + (v_end_time - v_begin_time);
    --插入数据
  end loop;
  commit;
  dbms_output.put_line(v_all_time);
end loop;
dbms_output.put_line(v_all_time);
end;

--好了,可以看看都插入了写什么数据,
select * from yard_test;


--下面开始测试
declare
  v_beg timestamp;--一定要记好开始时间
  v_end timestamp;--和结束时间
  v_times number := 100000;
begin
  --测试查找第50000条数据的速度
  v_beg := systimestamp;
  for i in 1..v_times loop
    execute immediate 'select * from yard_test where yrd_num = 50000';
    --用execute直接运行sql语句,这里是通过number查找数据
  end loop;
  v_end := systimestamp;
  dbms_output.put_line('number 查询时间 ' || (v_end-v_beg));
 
  v_beg := systimestamp;
  for i in 1..v_times loop
    execute immediate 'select * from yard_test where yrd_id = ''4A6585C231B64BD1B5A981EDD8079990''';
  end loop;
  v_end := systimestamp;
  dbms_output.put_line('char 查询时间 ' || (v_end-v_beg));
 
  v_beg := systimestamp;
  for i in 1..v_times loop
    execute immediate 'select * from yard_test where yrd_var = ''18C00CA4677E4BF388BD9F3891BBACA0''';
  end loop;
  v_end := systimestamp;
  dbms_output.put_line('carchar2 查询时间 ' || (v_end-v_beg));
end;

其实在网上我也发现有其他同学做的测试,结论也都一样...

都是 char 效率最高,number 其次,最慢的是varchar2,差的也不大,也都能接受。

linux

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门文章

仓库:如何复兴队友
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶体解释及其做什么(黄色晶体)
1 周前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热门文章

仓库:如何复兴队友
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶体解释及其做什么(黄色晶体)
1 周前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热门文章标签

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

减少在Docker中使用MySQL内存的使用 减少在Docker中使用MySQL内存的使用 Mar 04, 2025 pm 03:52 PM

减少在Docker中使用MySQL内存的使用

如何使用Alter Table语句在MySQL中更改表? 如何使用Alter Table语句在MySQL中更改表? Mar 19, 2025 pm 03:51 PM

如何使用Alter Table语句在MySQL中更改表?

mysql无法打开共享库怎么解决 mysql无法打开共享库怎么解决 Mar 04, 2025 pm 04:01 PM

mysql无法打开共享库怎么解决

什么是 SQLite?全面概述 什么是 SQLite?全面概述 Mar 04, 2025 pm 03:55 PM

什么是 SQLite?全面概述

在 Linux 中运行 MySQl(有/没有带有 phpmyadmin 的 podman 容器) 在 Linux 中运行 MySQl(有/没有带有 phpmyadmin 的 podman 容器) Mar 04, 2025 pm 03:54 PM

在 Linux 中运行 MySQl(有/没有带有 phpmyadmin 的 podman 容器)

在MacOS上运行多个MySQL版本:逐步指南 在MacOS上运行多个MySQL版本:逐步指南 Mar 04, 2025 pm 03:49 PM

在MacOS上运行多个MySQL版本:逐步指南

哪些流行的MySQL GUI工具(例如MySQL Workbench,PhpMyAdmin)是什么? 哪些流行的MySQL GUI工具(例如MySQL Workbench,PhpMyAdmin)是什么? Mar 21, 2025 pm 06:28 PM

哪些流行的MySQL GUI工具(例如MySQL Workbench,PhpMyAdmin)是什么?

如何保护MySQL免受常见漏洞(SQL注入,蛮力攻击)? 如何保护MySQL免受常见漏洞(SQL注入,蛮力攻击)? Mar 18, 2025 pm 12:00 PM

如何保护MySQL免受常见漏洞(SQL注入,蛮力攻击)?

See all articles