首 页IT知识库翔宇问吧收藏内容
当前位置:翔宇亭IT乐园IT知识库数据库Oracle

Oracle中的中文排序方式

减小字体 增大字体 作者:不详  来源:不详  发布时间:2010-02-09 11:02:00

     1. 测试中文排序的数据库版本

  SQL> select * from v$version;
  BANNER
  --------------------------------------------------------------------------------
  Oracle Database 11g Enterprise Edition Release 11.1.0.6.0 - Production
  PL/SQL Release 11.1.0.6.0 - Production
  CORE    11.1.0.6.0      Production
  TNS for Linux: Version 11.1.0.6.0 - Production
  NLSRTL Version 11.1.0.6.0 - Production

  2. 创建测试表

  create table player (id number(16, 0), name varchar2(30));

  3. 检查字符集配置

  确认数据库字符集 american_america.AL32UTF8
  SQL>  select  name,value$  from  props$;
  NAME                           VALUE$
  ------------------------------ ------------------------------
  DICT.BASE                      2
  DEFAULT_TEMP_TABLESPACE        TEMP
  DEFAULT_PERMANENT_TABLESPACE   USERS
  DEFAULT_EDITION                ORA$BASE
  Flashback Timestamp TimeZone   GMT
  TDE_MASTER_KEY_ID
  DEFAULT_TBS_TYPE               SMALLFILE
  NLS_LANGUAGE                   AMERICAN
  NLS_TERRITORY                  AMERICA
  NLS_CURRENCY                   $
  NLS_ISO_CURRENCY               AMERICA
  NLS_NUMERIC_CHARACTERS         .,
  NLS_CHARACTERSET               AL32UTF8
  NLS_CALENDAR                   GREGORIAN
  NLS_DATE_FORMAT                DD-MON-RR
  NLS_DATE_LANGUAGE              AMERICAN
  NLS_SORT                       BINARY
  NLS_TIME_FORMAT                HH.MI.SSXFF AM
  NLS_TIMESTAMP_FORMAT           DD-MON-RR HH.MI.SSXFF AM
     NLS_TIME_TZ_FORMAT             HH.MI.SSXFF AM TZR
  NLS_TIMESTAMP_TZ_FORMAT        DD-MON-RR HH.MI.SSXFF AM TZR
        NLS_DUAL_CURRENCY              $
  NLS_COMP                       BINARY
  NLS_LENGTH_SEMANTICS           BYTE
  NLS_NCHAR_CONV_EXCP            FALSE
  NLS_NCHAR_CHARACTERSET         AL16UTF16
  NLS_RDBMS_VERSION              11.1.0.6.0
  GLOBAL_DB_NAME                 ORA11G
  EXPORT_VIEWS_VERSION           8
  WORKLOAD_CAPTURE_MODE
  WORKLOAD_REPLAY_MODE
  DBTIMEZONE                     00:00
  32 rows selected.
  SQL>

  深入确认字符集
  SELECT DISTINCT (NLS_CHARSET_NAME(CHARSETID)) CHARACTERSET,
  DECODE(TYPE#, 1,
  DECODE(CHARSETFORM, 1, 'VARCHAR2', 2, 'NVARCHAR2', 'UNKOWN'),
  9,
  DECODE(CHARSETFORM, 1, 'VARCHAR', 2, 'NCHAR VARYING', 'UNKOWN'),
  96,
  DECODE(CHARSETFORM, 1, 'CHAR', 2, 'NCHAR', 'UNKOWN'),
  112,
  DECODE(CHARSETFORM, 1, 'CLOB', 2, 'NCLOB', 'UNKOWN')) TYPES_USED_IN
  FROM SYS.COL$
  WHERE CHARSETFORM IN (1, 2)
  AND TYPE# IN (1, 9, 96, 112);

  确认操作系统字符集设置

  [ora11g@bj55 ~]$ export NLS_LANG=american_america.al32utf8

  4. 填写测试数据
  。。。。
  SQL> insert into player values (17, '下午啦');
  1 row created.
  SQL> insert into player values (20, '八千米死亡线');
  SQL> set pagesize 60
  SQL>  select * from player;
  ID NAME
  1 中文
  2 中文拼音
  3 笔画输入法
  4 一
  5 二
  6 三
  7 四
  8 五
  9 六
  10 七
  12 八1
  13 八2
  14 九1
  15 十
  16 测试啊
  17 下午啦
  20 八千米死亡线
  17 rows selected.
  SQL>

[1] [2]  下一页

微信搜索“优雅的代码”关注本站的公众号,或直接使用微信扫描下面二维码关注本站公众号,以获取最新内容。

个人成长离不开各位的关注,你的关注就是我继续前行的动力。

Tags:Oracle 排序

知识评论评论内容只代表网友观点,与本站立场无关!

   评论摘要(共 0 条,得分 0 分,平均 0 分) 查看完整评论
愿您的精彩评论引起共鸣,带来思考和价值。
用户名: 查看更多评论
分 值:100分 90分 80分 70分 60分 40分 20分
内 容:
验证码:
关于本站 | 网站帮助 | 广告合作 | 网站声明 | 友情连接 | 网站地图
本站部分内容来自互联网,如有侵权,请来信告之,谢谢!
Copyright © 2007-2022 biye5u.com. All Rights Reserved.