Oracle字段类型设计与实际业务不符引发的问题

WBOY
发布: 2016-06-07 16:44:04
原创
953 人浏览过

在Oracle表的设计过程中,开发人员总是对字段的类型不以为然,下面来演示一个例子,按照应该设计为number的,结果设计成了varcha

在Oracle表的设计过程中,开发人员总是对字段的类型不以为然,下面来演示一个例子,按照应该设计为number的,结果设计成了varchar2,那会导致什么问题呢?下面我们来做一个实验。

SQL> create table test(id varchar2(10));

表已创建。
SQL> declare
  2    i number;
  3  begin
  4    for i in 1..100 loop
  5    insert into test values(i);
  6    end loop;
  7  end;
  8  /

PL/SQL 过程已成功完成。

SQL> commit;

提交完成。
SQL> select count(*) from test where id ----猜猜是多少,难道不是8?

  COUNT(*)
----------
        89

SQL> select count(*) from test where id

  COUNT(*)
----------
        11

SQL> select * from test where id

ID
----------
1
10
11
12
13
14
15
16
17
18
100

已选择11行。

总结:Oracle比较字符串是根据ASCII码来的,,第一个字母的ASCII大小比较如果相等再比较下一个,类推。

更多详情见请继续阅读下一页的精彩内容:

Oracle字段类型设计与实际业务不符引发的问题

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板