一个Jsp初学者的学习过程(七)

js|初学|过程

一个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("<","&lt");//用replaceAll()将字串中所有的<改成&lt
String newtext=text2.replaceAll(">","&gt");//用replaceAll()将字串中所有的>改成&gt
//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。

时间: 2024-11-10 11:07:03

一个Jsp初学者的学习过程(七)的相关文章

一个Jsp初学者的学习过程(八)

一个Jsp初学者的学习过程(八)TheUnforgiven第八章 图片文件的操作--Blob类型数据的存取和使用第一个Servlet 关于这部分内容,我在网上找到一些资料,最后按照我的需求,经过改编得到了下面的代码:------------------------------upphoto.htm------------------------------------<html><head><meta http-equiv="Content-Type" c

一个JSP初学者的学习过程详解

js|初学|过程|详解 前言 从现在开始我要把我学习Jsp的过程写出来.这些东西都是我从书本.网络上搜集整理的,我把它们据为己有后写这样一篇总结供如我一样的初学者参考. 请容许我在这里说一些和读者无关的话,对此不感兴趣的请直接跳到第一章或第二章. 我在2003年七月大学毕业,这之前学了四年计算机专业,由于基本是属于文科学校的计算机专业,学校女生少男生多学习的风气极受影响,所以可以想象我毕业时候的水平.在学校时学习的大多是枯燥的计算机理论知识,我虽知其有用,但实在不感兴趣,我感兴趣的是编码,于是学

登录 增删改查-初学者求一个JSP对数据库进行登录并增删改查的代码

问题描述 初学者求一个JSP对数据库进行登录并增删改查的代码 A 注:(发送失败的短信的存储表格) create table A ( list_id VARCHAR2(40) not null, task_id VARCHAR2(40), content VARCHAR2(2000), presend_dt DATE, final_dt DATE, status NUMBER default 0, caller VARCHAR2(40), chargenum VARCHAR2(40), call

a 标签传值乱码问题,从一个jsp传到另外一个jsp

问题描述 a 标签传值乱码问题,从一个jsp传到另外一个jsp 从jsp传到jsp ...........http://ask.csdn.net/my# 解决方案 用encodeURIComponent编码下,encodeURIComponent编码2次 而且你的shopName和goodsName要用引号括起,要不会出错.. var shopName=encodeURIComponent(encodeURIComponent('${param["shopName"]}')) var

编写一个JSP小程序

问题描述 编写一个JSP,产生一个随机数(0-9),将该随机数作为参数发送到处理页面,如果该随机数恰好是8,显示一段笑话,如果不是8,显示"真遗憾,再试一次".("再试一次"做超链接)怎么实现啊? 解决方案 解决方案二:作业题啊先看看java产生随机数类Random然后页面判断下就ok了解决方案三:先看看java产生随机数类RandomMath然后页面判断下就ok了[/Quote]解决方案四:晕,很明显是作业,哈哈~不能教坏小孩~自己看书去~解决方案五:这个很简单额

tomcat-我有一个jsp项目文件,但不会用,麻烦各位看看

问题描述 我有一个jsp项目文件,但不会用,麻烦各位看看 我有一个jsp项目文件,但不会用,不知道是放在tomcat,还是放到eclipse运行,各位看看 已经补全jar包 链接: http://pan.baidu.com/s/1jHsXCea 密码: ebfj 解决方案 一个JSP网上书店项目 解决方案二: 在eclipse建一个Dynamic Web project 项目,名字为app05a,然后把文件全部拷贝进去,把项目加入tomcat,然后就应该可以用了 解决方案三: 建议先了解Java

在JSP页面中怎么弹出另外一个JSP页面

问题描述 在JSP页面中怎么弹出另外一个JSP页面:举个例子,一个A页面和一个B页面,现在我就想在查询我们数据库的时候,如果我们的设备有误,就弹出B页面. 解决方案 解决方案二:window.open或者window.showModalDialog解决方案三:response.redirect解决方案四:引用1楼shixitong的回复: window.open或者window.showModalDialog 能具体一点吗?解决方案五:引用2楼yuzhuuse的回复: response.redi

用struts做一个JSP的登录界面,最后不能发布

问题描述 用struts做一个JSP的登录界面,最后不能发布,做出以下提示:2011-4-2817:16:58org.apache.catalina.core.AprLifecycleListenerinit信息:TheApacheTomcatNativelibrarywhichallowsoptimalperformanceinproductionenvironmentswasnotfoundonthejava.library.path:C:JaveMyEclipse6.0bin;C:Jave

高分求找高手修改一个jsp,开发工具是jbuilder和SQL 2000,

问题描述 找高手修改一个jsp,开发工具是jbuilder和SQL2000,有不明白的可加QQ729312472,小女子不胜感激类似于http://www.tinybbs.cn/asp/post/id~353但有所不同,谢谢现在下拉框已经能连接上数据库,需要西面框里面的内容也连接数据库实现动态更新,但是不能刷新页面!要实现下拉框选择NAME时,下面那个框同步显示CONTENT的内容,当点击"提交"时,转到下一个页面,原来页面不变但是"以下是分词结果"显示数据库中FE