您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

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

2024/3/16 9:48:28发布22次查看
在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大小比较如果相等再比较下一个,类推。
更多详情见请继续阅读下一页的精彩内容:
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product