> 데이터 베이스 > MySQL 튜토리얼 > Oracle字段类型设计与实际业务不符引发的问题

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

WBOY
풀어 주다: 2016-06-07 16:44:04
원래의
976명이 탐색했습니다.

在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

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿