您现在的位置:计算机技术学习网 > 技术中心 > WEB编程 > JSP >

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

来源:网络 责任编辑:栏目编辑 发表时间:2013-07-01 07:19 点击:
 一个jsp(SUN企业级应用的首选)初学者的学习过程(七)

TheUnforgiven


第七章  超长文本的操作——Clob类型数据的存取

    回到我编写留言板的时候,当时要存放留言板的正文内容,发现VARCHAR2()(可变长度的字符串)只能存4000字节,也就是2000个汉字,这也太少了啊,查一下数据库类型的资料,发现有这么几个类型:LONG,2G(要是我没记错的话,它是为了向前兼容,不推荐使用);CLOB,4G,字符;BLOB,4G,二进制。看来超长文本应该使用CLOB了,图片自然是用BLOB了,询问了一下别人,知道这两种类型是不能像VARCHAR2()那样直接存的,只好作罢,先用VARCHAR2()顶一阵。
    后来我终于有空了,决心要完成这个任务,在网上查了一番资料,看了别人的例子,总算是无师自通看明白了:存的时候需要使用empty_clob()(这个不是Java的函数)先存一个空的标识(用我的理解就是先初始化一下),然后通过“流”将数据写入。下面是代码,其中try里面的是CLOB类型的存操作:
-----------------------------------save_new.jsp(SUN企业级应用的首选)------------------------------------------
<%@ 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 xml(标准化越来越近了)ns="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

    相关新闻>>

      发表评论
      请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
      用户名: 验证码:点击我更换图片
      最新评论 更多>>

      推荐热点

      • JSP与Servlet
      • 自己动手写MiniBBS系列(基本篇)之用户登录
      • JSP取当前日期
      • JDBC 入门(一)
      • 打开一个jsp页面默认查询所有数据,调用action
      • 使用JSP标签库验证用户的输入(2)完
      • 自定义JSP标签(tag)浅议
      • WIN98/2000下的jsp服务器
      • JSP内建对象(二)
      网站首页 - 友情链接 - 网站地图 - TAG标签 - RSS订阅 - 内容搜索
      Copyright © 2008-2015 计算机技术学习交流网. 版权所有

      豫ICP备11007008号-1