WEB开发网      濠靛倻鏅悵顖涚附閽樺鐎诲ù婊庡亾缁辨帗鎷呴悩鍨暠濞戞挴鍋撳ù鐘烘閸ㄥ孩绂嶉锝喰﹂柟瀛樺灣濠婃垿鎯冮崟顏嗩伇濞寸姾妫勬慨鈺呭礉濞戝磭骞㈤悹鍥у槻閸ㄥ孩绂嶉敓锟� ---闁挎洩鎷�
开发学院数据库Oracle Oracle中CHAR类型自动补足空格的问题-性能调优 阅读

Oracle中CHAR类型自动补足空格的问题-性能调优

 2008-11-14 12:59:28 来源:WEB开发网 闁靛棴鎷�闁告垵绻愰惃顒傗偓娑欍仦缂嶏拷濠⒀呭仜閵囧洨鈧稒銇炵紞锟�闁靛棴鎷�  闁稿繗娅曢弫鐐垫嫬闁垮鈧秹鏌ㄧ€靛憡鐣辩€甸偊鍠栧畷锟�
核心提示:在ORACLE中,CHAR类型的字段值会自动补足空格,Oracle中CHAR类型自动补足空格的问题-性能调优,所以当其作为条件时,就有可能查不出想要的数据, 网管论坛bbs_bitsCN_com 如果不允许改DB设计的话,那就用RTRIM来解决吧

在ORACLE中,CHAR类型的字段值会自动补足空格。所以当其作为条件时,就有可能查不出想要的数据。 网管论坛bbs_bitsCN_com

如果不允许改DB设计的话,那就用RTRIM来解决吧。例:

网管下载dl.bitscn.com

DB:

网管u家u.bitsCN.com

CREATETABLETEST
(
  TEST_ID            VARCHAR2(64)NOTNULL,
  网管网www.bitscn.com
  TEST_CHAR           CHAR(10),
  CONSTRAINTTEST_IDPRIMARYKEY(TEST_ID)
);
INSERTINTOTESTVALUES('1','a');

网管论坛bbs_bitsCN_com

测试代码:

网管下载dl.bitscn.com

Sessionsession=factory.getCurrentSession();
session.beginTransaction();
Listlist=session.createQuery("FROMTestWHERERTRIM(TEST_CHAR)='a'").list();
session.close(); 网管联盟bitsCN@com
assertTrue(list.size()>0);

网管u家www.bitscn.net

输出结果(ORACLE): 网管网www_bitscn_com

Hibernate:
  select
    test0_.TEST_IDasTEST1_0_,
    test0_.TEST_CHARasTEST4_0_
  from
  网管朋友网www_bitscn_net
    TESTtest0_
  where
    rtrim(TEST_CHAR)='a'
14:09:53,171DEBUGStringType:172-returning'1'ascolumn:TEST1_0_ 网管u家www.bitscn.net
14:09:53,187DEBUGStringType:172-returning'a    'ascolumn:TEST4_0_

中国网管联盟bitsCN.com

而MySQL不会自动补足空格,同样的代码也是可以适用的:输出结果(MySQL):

网管网www.bitscn.com

Hibernate:
  select
    test0_.TEST_IDasTEST1_0_,
    test0_.TEST_CHARasTEST4_0_
  from
  网管网www.bitscn.com
    TESTtest0_
  where
    rtrim(TEST_CHAR)='a'
14:09:01,828DEBUGStringType:172-returning'1'ascolumn:TEST1_0_ 网管u家u.bitsCN.com
14:09:01,828DEBUGStringType:172-returning'a'ascolumn:TEST4_0_

网管有家bitscn.net

Tags:Oracle CHAR 类型

编辑录入:爽爽 [复制链接] [打 印]
赞助商链接