Maison > base de données > tutoriel mysql > Oracle字段类型设计与实际业务不符引发的问题

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

WBOY
Libérer: 2016-06-07 16:44:04
original
955 Les gens l'ont consulté

在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大小比较如果相等再比较下一个,类推。

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

linux

source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal