2009年3月22日

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 阅读(474) | 评论 (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 阅读(323) | 评论 (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 阅读(240) | 评论 (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 阅读(681) | 评论 (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 阅读(4054) | 评论 (0)编辑 收藏