| 
         
     
     | 
     | 
    
  
    | 
    一个Jsp初学者的学习过程(七) | 
   
  
     | 
   
  
     | 
   
  
    | 
     作者:未知  来源:月光软件站  加入时间:2005-5-13 月光软件站  | 
   
  
     一个Jsp初学者的学习过程(七)
  TheUnforgiven
 
  第七章  超长文本的操作——Clob类型数据的存取
      回到我编写留言板的时候,当时要存放留言板的正文内容,发现VARCHAR2()(可变长度的字符串)只能存4000字节,也就是2000个汉字,这也太少了啊,查一下数据库类型的资料,发现有这么几个类型:LONG,2G(要是我没记错的话,它是为了向前兼容,不推荐使用);CLOB,4G,字符;BLOB,4G,二进制。看来超长文本应该使用CLOB了,图片自然是用BLOB了,询问了一下别人,知道这两种类型是不能像VARCHAR2()那样直接存的,只好作罢,先用VARCHAR2()顶一阵。     后来我终于有空了,决心要完成这个任务,在网上查了一番资料,看了别人的例子,总算是无师自通看明白了:存的时候需要使用empty_clob()(这个不是Java的函数)先存一个空的标识(用我的理解就是先初始化一下),然后通过“流”将数据写入。下面是代码,其中try里面的是CLOB类型的存操作: -----------------------------------save_new.jsp------------------------------------------ <%@ include file="include.inc"%> <%@ page contentType="text/html;charset=gb2312" errorPage="request_error.htm"%> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> <title>无标题文档</title> </head> <body> <% String title = request.getParameter("title"); String kind=request.getParameter("kind"); String newtitle=title.replaceAll("'","''");//用replaceAll()将text字串中所有的单引号改成连续两个单引号
  String text = request.getParameter("text"); //String text1=text.replaceAll("'","''");存clob时不需将单引号改成连续两个单引号 String text2=text.replaceAll("<","<");//用replaceAll()将字串中所有的<改成< String newtext=text2.replaceAll(">",">");//用replaceAll()将字串中所有的>改成> //replace只能处理单个字符!! //改'是为了不影响数据库的查询语句 //改<>是防止网页把他们生成标签,比如:<table>,<form>等 String author=session.getAttribute("name").toString(); out.println(author); long ID=System.currentTimeMillis();//取得一个时间,从1970-1-1 0:00:00开始到当前时间的毫秒数,用这个数作为该文章的ID标识 java.text.SimpleDateFormat formatter = new java.text.SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); //格式化日期 java.util.Date currentTime_1 = new java.util.Date();//得到当前系统时间 String strdate = formatter.format(currentTime_1); //将日期时间转换成字符串形式
  Connection con = null; PreparedStatement stmt = null;//不能用Statement,我也不知道为什么,查了API,说这个PreparedStatement可以用于                               //高效的多次执行语句,没查到Statement这个类 ResultSet rs = null; try {  Class.forName(CLASSFORNAME);//载入驱动程式类别  con=DriverManager.getConnection(SERVANDDB);//建立数据库连接  con.setAutoCommit(false);//设置不自动提交  String sql="insert into article(id,author,title,time,kind,text_clob) values ('"+ID+"','"+author+"','"+newtitle+"','"+strdate+"','"+kind+"',empty_clob())";//我的数据库中存文本的CLOB型字段名为:text_clob  stmt=con.prepareStatement(sql);//添加一条clob字段为空的记录,  stmt.executeUpdate();//执行  stmt=null;//下次使用前清空  sql="select text_clob from article where id='"+ID+"' for update";//正是由于这条语句,id这个标识就必须得唯一!!!!  //如果数据库中已有一条记录的id与当前的id值相同,那么会查到那条记录,也就无法向新插入的记录中的clob字段进行写入!  stmt=con.prepareStatement(sql);//查找刚刚添加的那条记录  rs=stmt.executeQuery();    oracle.sql.CLOB osc = null;//初始化一个空的clob对象  if (rs.next())      osc=(oracle.sql.CLOB)rs.getClob("text_clob");  Writer w=osc.getCharacterOutputStream();//使用字符输出流  w.write(newtext);//将字符串str_text写到流中  w.flush();//输出流中数据,大概是正式向clob中写了  w.close();  con.commit();//执行  response.sendRedirect("index.jsp?page=1");//回主页面 } catch(Exception e) {out.println(e);} finally {   if (rs!=null)     rs.close();   if (stmt!=null)     stmt.close();   if (con!=null)     con.close(); }  %> </body> </html> -------------------------------------------------------------------------- 取的时候就相对简单了,主要就两句,看下面的代码: -------------------------------------------------------------------------- <% Connection con = null; Statement stmt = null; ResultSet rs = null; long ID=Long.parseLong(request.getParameter("ID"));//将接收到的字符串转成long型 try {  Class.forName(CLASSFORNAME);//载入驱动程式类别  con=DriverManager.getConnection(SERVANDDB);//建立数据库连接  stmt=con.createStatement();  String sql="select * from Article where ID='"+ID+"'";  rs=stmt.executeQuery(sql);  if (rs.next())    { //下2行是用于从clob类型里读数据的,转成字符串。         oracle.sql.CLOB osc=(oracle.sql.CLOB)rs.getClob("text_clob");//我的数据库中存文本的CLOB型字段名为:text_clob      String str_text=osc.getSubString((long)1,(int)osc.length());//subString是截取字符串(从1截到length),如果用 osc.getString的话出错。         out.print(str_text);    }//if }//try   catch(Exception e){}   rs.close();   stmt.close();   con.close();     %> --------------------------------------------------------------------------     现在对CLOB类型的存取问题已经解决,但是当你操作文本字符串的时候你会发现很多问题,比如说,文本里有单引号(')、标签(如<table>、<br>),还有回车和空格的问题等等,都需要你在实践中发现并解决。     下一章说说BLOB。
 
  
 
  | 
   
  
     | 
   
  
     相关文章:相关软件:  | 
   
   
      |