在一个表中,有一个字段是 clob 类型,现在我要用一个sql语句查询并显示到页面中,该如何写。使用select dbms_lob.substr(a.desc, 2000,1) as desc from table a 只能查询截取4000字符的内容,要查询出全部内容怎么办呢?最好能用一个sql写出来谢谢各位了。

解决方案 »

  1.   

    你用的是JAVA语言吗?
    如果是JAVA,可以试试以下解决方法可以
    Statement stmt = null;
    ResultSet rs = null;
    List rList = new ArrayList();stmt = con.createStatement();
    rs = stmt.executeQuery(query.toString());
    ResultSetMetaData rsmd = rs.getMetaData();
    int numberOfColumns = rsmd.getColumnCount();
    String columnLabel = "";
    while(rs.next()){
        rMap = new MapBEAN();
        for(int i=1 ; i <= numberOfColumns ; i++){
            columnLabel    = rsmd.getColumnLabel(i);
    if(columnLabel.equals("desc")){
        oracle.sql.CLOB clob=(CLOB) rs.getClob(i);
        if(clob != null && (int)clob.length()>0)
                    rMap.set(columnLabel, clob.getSubString((long)1, (int)clob.length()));
                else
                    rMap.set(columnLabel,"");
    }else{
        rMap.set(columnLabel, rs.getString(i));
    }
        }
        rList.add(rMap);
    }

    return rList;
      

  2.   


    OracleConnection myCn = new OracleConnection(strConn);      
           OracleCommand myCmd = new OracleCommand();
           try
           {
             myCn.Open();         
           }
           catch(System.Data.OracleClient.OracleException e)
           {
             throw new Exception(e.Message);
           }      
           OracleTransaction myTrans = myCn.BeginTransaction();
           try
           {                       
             myCmd.Connection = myCn;         
             myCmd.Transaction = myTrans;
             myCmd.CommandText = "SELECT * FROM "+ table_name +" where "+ table_id +" = "+ id +" FOR UPDATE";
             OracleDataReader reader = myCmd.ExecuteReader();
             using(reader)
             {
               reader.Read();
               OracleLob CLOB = reader.GetOracleLob(column);
               int[] content = new int[(int)CLOB.Length];
               byte[] buffer = new byte[(int)CLOB.Length];
                  
               for(int i = 0;i&lt;(int)CLOB.Length;i++)
               {
                 content[i] = CLOB.ReadByte();
                 buffer[i]  = (byte)content[i];
               }
      
               Encoding utf8 = Encoding.UTF8;
                
               string final = utf8.GetString(buffer);
               myTrans.Commit();
               return final;
             }
           }
           catch(System.Data.OracleClient.OracleException e)
           {      
             myTrans.Rollback();
             throw new Exception(e.Message);
           }
           finally
           {
             myCmd.Dispose();
             myCn.Close();
           }