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
存:
ps.setCharacterStream(4, new StringReader("String", "String".length());
取:
rs.getString("clob");
jdk 1.6以后
可以使用
Clob clob=connetion.createClob();
Writer wr=clob.setCharacterStream(0);
//对wr写入信息
ps.setClob(clob);
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
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}