2008年12月20日

10g的数据库导成9i的

ORACLE EXP-00003: 未找到段 (4,131) 的存储定义
用oracle9i的客户端连接10g的数据库,然后执行以下脚本。
 

在导出前, 连接到SYS用户, 运行以下SQL: 
CREATE OR REPLACE VIEW exu9tne ( 
tsno, fileno, blockno, length) AS 
SELECT ts#, segfile#, segblock#, length 
FROM sys.uet$ 
WHERE ext# = 1 
UNION ALL 
SELECT * FROM SYS.EXU9TNEB 
导出完成后,再复原这个view(定义可以通过user_views看到) 对于oracle9i和oracle10g这个定义都相同: 
CREATE OR REPLACE VIEW exu9tne ( 
tsno, fileno, blockno, length) AS 
SELECT ts#, segfile#, segblock#, length 
FROM sys.uet$ 
WHERE ext# = 1 
posted @ 2010-12-01 16:30 Bom Wu 阅读(473) | 评论 (0)编辑 收藏
 
存:
ps.setCharacterStream(4new StringReader("String""String".length());
取:
rs.getString("clob");

jdk 1.6以后
可以使用
Clob clob=connetion.createClob();
Writer wr
=clob.setCharacterStream(0);
//对wr写入信息
ps.setClob(clob);
posted @ 2010-10-14 16:09 Bom Wu 阅读(322) | 评论 (0)编辑 收藏
 

inux操作系统定时任务系统 Cron 入门


  cron是一个linux下 的定时执行工具 ,可以在无需人工干预的情况下运行作业。由于Cron 是Linux 的内置 服务,但它不自动起来,可以用以下的方法 启动、关闭 这个服务:

  /sbin/service crond start //启动服务

  /sbin/service crond stop //关闭服务

  /sbin/service crond restart //重启服务

  /sbin/service crond reload //重新载入配置

  你也可以将这个服务在系统启动的时候自动启动:

  在/etc /rc.d/rc.local 这个脚本的末尾加上:

  /sbin/service crond start

  现在C ron这个服务已经在进程里面了,我们就可以用这个服务了,Cron服务提供以下几种接口供大家使用:

  1.直接用crontab 命令编辑

  cron服务提供crontab命令来设定cron服务的,以下是这个命令的一些参数 与说明:

  crontab -u //设定某个用户的cron服务,一般root 用户在执行 这个命令的时候需要此参数

  crontab -l //列出某个用户cron服务的详细内容

  crontab -r //删除 没个用户的cron服务

  crontab -e //编辑某个用户的cron服务

  比如说root查看自己的cron设置:crontab -u root -l

  再例如,root想删除fred的cron设置:crontab -u fred -r

  在编辑cron服务时,编辑的内容有一些格式和约定,输入:crontab -u root -e

  进入vi 编辑模式 ,编辑的内容一定要符合下面的格式:*/1 * * * * ls >> /tmp/ls.tx t

任务调度的crond常驻命令
crond 是linux用来定期执行程序的命令。当安装完成操作系统之后,默认便会启动此任务调度命令。crond命令每分锺会定期检查是否有要执行的工作,如果有要执行的工作便会自动执行该工作。

1、linux任务调度的工作主要分为以下两类:
    *系统执行的工作:系统周期性所要执行的工作,如备份系统数据、清理缓存
    *个人执行的工作:某个用户定期要做的工作,例如每隔10分钟检查邮件服务器是否有新信,这些工作可由每个用户自行设置。

2.crontab命令选项:
    -u指定一个用户,
    -l列出某个用户的任务计划,
    -r删除某个用户的任务,
    -e编辑某个用户的任务

3.cron文件语法:
          分    小时   日      月      星期     命令
        0-59  0-23  1-31  1-12    0-6    command    (取值范围,0表示周日一般一行对应一个任务)

4.记住几个特殊符号的含义:
        "*"代表取值范围内的数字,
        "/"代表"每",
        "-"代表从某个数字到某个数字,
        ","分开几个离散的数字


一、任务调度设置文件的写法

      可用crontab -e命令来编辑,编辑的是/var/spool/cron下对应用户的cron文件,也可以直接修改/etc/crontab文件
具体格式如下:
      Minute Hour Day Month Dayofweek   command
      分钟    小时  天    月       天每星期       命令

每个字段代表的含义如下:
      Minute            每个小时的第几分钟执行该任务
     Hour               每天的第几个小时执行该任务
     Day                每月的第几天执行该任务
     Month             每年的第几个月执行该任务
     DayOfWeek    每周的第几天执行该任务
     Command       指定要执行的程序
      在这些字段里,除了“Command”是每次都必须指定的字段以外,其它字段皆为可选字段,可视需要决定。对于不指定的字段,要用“*”来填补其位置。

举例如下:
5      *       *          *     *    ls             指定每小时的第5分钟执行一次ls命令
30    5      *          *     *    ls             指定每天的 5:30 执行ls命令
30    7      8         *     *     ls             指定每月8号的7:30分执行ls命令
30    5      8         6    *     ls             指定每年的6月8日5:30执行ls命令
30    6      *          *    0     ls             指定每星期日的6:30执行ls命令 [ 注:0表示星期天,1表示星期1,以此类推,也可以用英文来表示,sun表示星期天,mon表示星期一等。 ]
30    3     10,20    *    *     ls    每月10号及20号的3:30执行ls命令 [注:“,”用来连接多个不连续的时段 ]
25    8-11 *           *    *     ls      每天8-11点的第25分钟执行ls命令 [注:“-”用来连接连续的时段 ]
*/15  *       *           *    *     ls          每15分钟执行一次ls命令 [即每个小时的第0 15 30 45 60分钟执行ls命令  ]
30   6     */10        *     *     ls       每个月中,每隔10天6:30执行一次ls命令[即每月的1、11、21、31日是的6:30执行一次ls命令。  ]
每天7:50以root 身份执行/etc/cron.daily目录中的所有可执行文件
50   7      *            *     *    root     run-parts     /etc/cron.daily   [ 注:run-parts参数表示,执行后面目录中的所有可执行文件。  ]

二、新增调度任务

新增调度任务可用两种方法:
        1、在命令行输入: crontab -e 然后添加相应的任务,wq存盘退出。
        2、直接编辑/etc/crontab 文件,即vi /etc/crontab,添加相应的任务。

三、查看调度任务

        crontab -l //列出当前的所有调度任务
        crontab -l -u jp   //列出用户jp的所有调度任务

四、删除任务调度工作

        crontab -r  //删除所有任务调度工作

五、任务调度执行结果的转向

     例1:每天5:30执行ls命令,并把结果输出到/jp/test文件中
        30 5 * * * ls >/jp/test 2>&1
     注:2>&1 表示执行结果及错误信息。


编辑/etc/crontab 文件配置cron

  cron服务每分钟不仅要读一次/var/spool/cron内的所有文件,还需要读一次/etc/crontab,因此我们配置这个文件也能运用cron服务做一些事情。用crontab配置是针对某个用户的,而编辑/etc/crontab是针对系统的任务。此文件的文件格式是:

  SHELL=/bin/bash 

  PATH=/sbin:/bin:/usr/sbin:/usr/bin 

  MAILTO=root //如果出现错误,或者有数据输出,数据作为邮件发给这个帐号 

  HOME=/ //使用者运行的路径,这里是根目录 

  # run-parts 

  01   *   *   *   *     root run-parts /etc/cron.hourly          //每小时执行/etc/cron.hourly内的脚本 

  02   4   *   *   *     root run-parts /etc/cron.daily            //每天执行/etc/cron.daily内的脚本 

  22   4   *   *   0     root run-parts /etc/cron.weekly        //每星期执行/etc/cron.weekly内的脚本 

  42   4   1   *   *     root run-parts /etc/cron.monthly      //每月去执行/etc/cron.monthly内的脚本 

  大家注意"run-parts"这个参数了,如果去掉这个参数的话,后面就可以写要运行的某个脚本名,而不是文件夹名了

例如:        1、在命令行输入: crontab -e 然后添加相应的任务,wq存盘退出。
        2、直接编辑/etc/crontab 文件,即vi /etc/crontab,添加相应的任务

11 2 21 10 * rm -rf /mnt/fb

posted @ 2009-09-17 11:28 Bom Wu 阅读(239) | 评论 (0)编辑 收藏
 
 1
 2import java.util.Date;
 3import java.util.Properties;
 4
 5import javax.mail.Authenticator;
 6import javax.mail.Message;
 7import javax.mail.MessagingException;
 8import javax.mail.PasswordAuthentication;
 9import javax.mail.Session;
10import javax.mail.Transport;
11import javax.mail.internet.AddressException;
12import javax.mail.internet.InternetAddress;
13import javax.mail.internet.MimeMessage;
14
15public class EmailUtils {
16
17    private static Properties props;
18
19    private static Session session;
20
21    // 初始化session
22    static {
23        props = System.getProperties();
24        props.put("mail.transport.protocol""stmp");// 设置邮件服务器的协议
25        props.put("mail.host""smtp.qq.com");// 设置邮件发送服务器地址,该地址由邮件服务供应商提供,这里以QQ邮箱为例
26        props.put("mail.smtp.auth""true");// 设置邮件发送服务器需要用户验证,即需要账号密码才能登录邮箱
27        session = Session.getInstance(props, new Authenticator() {// 通过配置获取一个会话,第二个参数为验证类
28                    @Override
29                    protected PasswordAuthentication getPasswordAuthentication() {
30                        return new PasswordAuthentication("your email acount",
31                                "your email password"); // 在这里指定登录邮件发送服务器的账号与密码
32                        // QQ邮箱的账号默认为 QQ号@qq.com 密码为QQ密码
33                    }

34                }
);
35        // session.setDebug(true); //设置是否为Debug模式,如果为Debug模式,将输出中间信息。
36    }

37
38    /**
39     * 发送邮件
40     * 
41     * @param emailTo
42     *            收件人信箱
43     * @param title
44     *            主题
45     * @param msgs
46     *            内容
47     */

48    public static void sendEmail(String emailTo, String title, String msgs) {
49        System.out.println(msgs);
50        Message msg = new MimeMessage(session); // 该类封装了邮件发送的内容
51        try {
52            // 设置发件人地址,可以是个假的!
53            msg.setFrom(new InternetAddress("bom1987120@qq.com"));
54            // 设置收件人
55            msg.setRecipients(Message.RecipientType.TO, InternetAddress.parse(
56                    emailTo, false));
57            // 设置主题
58            msg.setSubject(title);
59            // 设置内容
60            msg.setText(msgs);
61            // 设置邮件头
62            msg.setHeader("X-Mailer""www.dangdang.com");
63            // 设置发送时间
64            msg.setSentDate(new Date());
65
66            // 发送!
67            Transport.send(msg);
68
69            System.out.println("Mail was sent successfully.\n");
70        }
 catch (AddressException e) {
71            e.printStackTrace();
72        }
 catch (MessagingException e) {
73            e.printStackTrace();
74        }

75    }

76
77    //测试
78    public static void main(String[] argv) {
79        for (int i = 0; i < 1000; i++)
80            sendEmail("XXXX@qq.com""Java Mail 测试""这是程序自动给你发的!");
81    }

82
83}
posted @ 2009-06-13 15:13 Bom Wu 阅读(677) | 评论 (0)编辑 收藏
 
首先必须在JSP中声明这个标签库:
<%@ taglib prefix="fn" uri="http://java.sun.com/jsp/jstl/functions" %>

调用方式为:fn:functionName(arg,...)
比如:${fn:length(aCollection)}
length是JSTL库中自带的函数,除此之外常的还有:

函数

描述

fn:contains(string, substring)

如果参数string中包含参数substring,返回true

fn:containsIgnoreCase(string, substring)

如果参数string中包含参数substring(忽略大小写),返回true

fn:endsWith(string, suffix)

如果参数 string 以参数suffix结尾,返回true

fn:escapeXml(string)

将有特殊意义的XML (和HTML)转换为对应的XML character entity code,并返回

fn:indexOf(string, substring)

返回参数substring在参数string中第一次出现的位置

fn:join(array, separator)

将一个给定的数组array用给定的间隔符separator串在一起,组成一个新的字符串并返回。

fn:length(item)

返回参数item中包含元素的数量。参数Item类型是数组、collection或者String。如果是String类型,返回值是String中的字符数。

fn:replace(string, before, after)

返回一个String对象。用参数after字符串替换参数string中所有出现参数before字符串的地方,并返回替换后的结果

fn:split(string, separator)

返回一个数组,以参数separator 为分割符分割参数string,分割后的每一部分就是数组的一个元素

fn:startsWith(string, prefix)

如果参数string以参数prefix开头,返回true

fn:substring(string, begin, end)

返回参数string部分字符串, 从参数begin开始到参数end位置,包括end位置的字符

fn:substringAfter(string, substring)

返回参数substring在参数string中后面的那一部分字符串

fn:substringBefore(string, substring)

返回参数substring在参数string中前面的那一部分字符串

fn:toLowerCase(string)

将参数string所有的字符变为小写,并将其返回

fn:toUpperCase(string)

将参数string所有的字符变为大写,并将其返回

fn:trim(string)

去除参数string 首尾的空格,并将其返回

posted @ 2009-03-22 16:19 Bom Wu 阅读(4053) | 评论 (0)编辑 收藏
 

 

一、EL简介
1.语法结构
    ${expression}
2.[]与.运算符
    EL 提供.和[]两种运算符来存取数据。
    当要存取的属性名称中包含一些特殊字符,如.或?等并非字母或数字的符号,就一定要使用 []。例如:
        ${user.My-Name}应当改为${user["My-Name"] }
    如果要动态取值时,就可以用[]来做,而.无法做到动态取值。例如:
        ${sessionScope.user[data]}中data 是一个变量
3.变量
    EL存取变量数据的方法很简单,例如:${username}。它的意思是取出某一范围中名称为username的变量。
    因为我们并没有指定哪一个范围的username,所以它会依序从Page、Request、Session、Application范围查找。
    假如途中找到username,就直接回传,不再继续找下去,但是假如全部的范围都没有找到时,就回传null。
    属性范围在EL中的名称
        Page         PageScope
        Request         RequestScope
        Session         SessionScope
        Application     ApplicationScope
       
二、EL隐含对象
1.与范围有关的隐含对象
与范围有关的EL 隐含对象包含以下四个:pageScope、requestScope、sessionScope 和applicationScope;
它们基本上就和JSP的pageContext、request、session和application一样;
在EL中,这四个隐含对象只能用来取得范围属性值,即getAttribute(String name),却不能取得其他相关信息。

例如:我们要取得session中储存一个属性username的值,可以利用下列方法:
    session.getAttribute("username") 取得username的值,
在EL中则使用下列方法
    ${sessionScope.username}

2.与输入有关的隐含对象
与输入有关的隐含对象有两个:param和paramValues,它们是EL中比较特别的隐含对象。

例如我们要取得用户的请求参数时,可以利用下列方法:
    request.getParameter(String name)
    request.getParameterValues(String name)
在EL中则可以使用param和paramValues两者来取得数据。
    ${param.name}
    ${paramValues.name}

3.其他隐含对象

cookie
JSTL并没有提供设定cookie的动作,
例:要取得cookie中有一个设定名称为userCountry的值,可以使用${cookie.userCountry}来取得它。

header和headerValues
header 储存用户浏览器和服务端用来沟通的数据
例:要取得用户浏览器的版本,可以使用${header["User-Agent"]}。
另外在鲜少机会下,有可能同一标头名称拥有不同的值,此时必须改为使用headerValues 来取得这些值。

initParam
initParam取得设定web站点的环境参数(Context)
例:一般的方法String userid = (String)application.getInitParameter("userid");
    可以使用 ${initParam.userid}来取得名称为userid

pageContext
pageContext取得其他有关用户要求或页面的详细信息。
    ${pageContext.request.queryString}         取得请求的参数字符串
    ${pageContext.request.requestURL}         取得请求的URL,但不包括请求之参数字符串
    ${pageContext.request.contextPath}         服务的web application 的名称
    ${pageContext.request.method}           取得HTTP 的方法(GET、POST)
    ${pageContext.request.protocol}         取得使用的协议(HTTP/1.1、HTTP/1.0)
    ${pageContext.request.remoteUser}         取得用户名称
    ${pageContext.request.remoteAddr }         取得用户的IP 地址
    ${pageContext.session.new}             判断session 是否为新的
    ${pageContext.session.id}               取得session 的ID
    ${pageContext.servletContext.serverInfo}   取得主机端的服务信息

三、EL运算符
1.算术运算符有五个:+、-、*或$、/或div、%或mod
2.关系运算符有六个:==或eq、!=或ne、<或lt、>或gt、<=或le、>=或ge
3.逻辑运算符有三个:&&或and、||或or、!或not
4.其它运算符有三个:Empty运算符、条件运算符、()运算符
    例:${empty param.name}、${A?B:C}、${A*(B+C)}

四、EL函数(functions)。
语法:ns:function( arg1, arg2, arg3 …. argN)
其中ns为前置名称(prefix),它必须和taglib 指令的前置名称一置

---------------------------------------------

补充:

<%@ taglib prefix="c" uri="http://java.sun.com/jstl/core_rt" %>

FOREACH:

<c:forEach items="${messages}"
var="item"
begin="0"
end="9"
step="1"
varStatus="var">
……
</c:forEach>

 

OUT:

<c:out value="/${logininfo.username}"/>
c:out>将value 中的内容输出到当前位置,这里也就是把logininfo 对象的
username属性值输出到页面当前位置。
${……}是JSP2.0 中的Expression Language(EL)的语法。它定义了一个表达式,
其中的表达式可以是一个常量(如上),也可以是一个具体的表达语句(如forEach循环体中
的情况)。典型案例如下:
Ø ${logininfo.username}
这表明引用logininfo 对象的username 属性。我们可以通过“.”操作符引
用对象的属性,也可以用“[]”引用对象属性,如${logininfo[username]}
与${logininfo.username}达到了同样的效果。
“[]”引用方式的意义在于,如果属性名中出现了特殊字符,如“.”或者“-”,
此时就必须使用“[]”获取属性值以避免语法上的冲突(系统开发时应尽量避免
这一现象的出现)。
与之等同的JSP Script大致如下:
LoginInfo logininfo =
(LoginInfo)session.getAttribute(“logininfo”);
String username = logininfo.getUsername();
可以看到,EL大大节省了编码量。
这里引出的另外一个问题就是,EL 将从哪里找到logininfo 对象,对于
${logininfo.username}这样的表达式而言,首先会从当前页面中寻找之前是
否定义了变量logininfo,如果没有找到则依次到Request、Session、
Application 范围内寻找,直到找到为止。如果直到最后依然没有找到匹配的
变量,则返回null.
如果我们需要指定变量的寻找范围,可以在EL表达式中指定搜寻范围:
${pageScope.logininfo.username}
${requestScope.logininfo.username}
${sessionScope.logininfo.username}
${applicationScope.logininfo.username}
在Spring 中,所有逻辑处理单元返回的结果数据,都将作为Attribute 被放
置到HttpServletRequest 对象中返回(具体实现可参见Spring 源码中
org.springframework.web.servlet.view.InternalResourceView.
exposeModelAsRequestAttributes方法的实现代码),也就是说Spring
MVC 中,结果数据对象默认都是requestScope。因此,在Spring MVC 中,
以下寻址方法应慎用:
${sessionScope.logininfo.username}
${applicationScope.logininfo.username}
Ø ${1+2}
结果为表达式计算结果,即整数值3。
Ø ${i>1}
如果变量值i>1的话,将返回bool类型true。与上例比较,可以发现EL会自
动根据表达式计算结果返回不同的数据类型。
表达式的写法与java代码中的表达式编写方式大致相同。


IF / CHOOSE:

<c:if test="${var.index % 2 == 0}">
*
</c:if>
判定条件一般为一个EL表达式。
<c:if>并没有提供else子句,使用的时候可能有些不便,此时我们可以通过<c:choose>
tag来达到类似的目的:
<c:choose>
<c:when test="${var.index % 2 == 0}">
*
</c:when>
<c:otherwise>
!
</c:otherwise>
</c:choose>
类似Java 中的switch 语句,<c:choose>提供了复杂判定条件下的简化处理手法。其
中<c:when>子句类似case子句,可以出现多次。上面的代码,在奇数行时输出“*”号,
而偶数行时输出“!”。
---------------------------------------------

再补充:

1    EL表达式用${}表示,可用在所有的HTML和JSP标签中 作用是代替JSP页面中复杂的JAVA代码.

        2   EL表达式可操作常量 变量 和隐式对象. 最常用的 隐式对象有${param}和${paramValues}. ${param}表示返回请求参数中单个字符串的值. ${paramValues}表示返回请求参数的一组值.pageScope表示页面范围的变量.requestScope表示请求对象的变量. sessionScope表示会话范围内的变量.applicationScope表示应用范围的变量.

        3   <%@ page isELIgnored="true"%> 表示是否禁用EL语言,TRUE表示禁止.FALSE表示不禁止.JSP2.0中默认的启用EL语言.

        4   EL语言可显示 逻辑表达式如${true and false}结果是false    关系表达式如${5>6} 结果是false     算术表达式如 ${5+5} 结果是10

        5   EL中的变量搜索范围是:page request session application   点运算符(.)和"[ ]"都是表示获取变量的值.区别是[ ]可以显示非词类的变量

posted @ 2009-03-14 19:46 Bom Wu 阅读(573) | 评论 (0)编辑 收藏
 

 

JTextArea jta=new JTextArea(20,20);
JScrollPane jsp
=new JScrollPane(jta);
jta.addMouseWheelListener(
new MouseWheelListener(){
 
public void mouseWheelMoved(MouseWheelEvent e){
   jsp.dispatchEvent(e); 
//将事件交给JScrollPane处理
}

}
);
这样在JTextArea里滚动鼠标,滚动条就会滚动
posted @ 2008-12-30 10:13 Bom Wu 阅读(342) | 评论 (0)编辑 收藏
 
圣诞快乐 圣诞快乐
posted @ 2008-12-24 19:28 Bom Wu 阅读(160) | 评论 (0)编辑 收藏
 
    JOptionPane调用静态方法弹出对话框时,按钮的语言为默认的本地语言,使用Locale.setDefaul()方法改变语言后,JOptionPane对话框的语言不能刷新,这时还应该改变JCompenent的默认Locale。
例,改为英文:

Locale.setDefault(Locale.ENGLISH);
sun.awt.AppContext.getAppContext().put("JComponent.defaultLocale", Locale.ENGLISH);
posted @ 2008-12-20 15:32 Bom Wu 阅读(582) | 评论 (0)编辑 收藏