ssh web 应用使用c3p0数据库连接池
ibm 给出的实例说明 将ssh web应用程序从tomcat迁移到websphere(was)
WAS 中数据源的配置使用及其常见问题
开源DBCP、C3P0、Proxool 、 BoneCP连接池的比较
月度归档:2013年10月
quartz demo
QuartzJob 类:创建job类,实现org.quartz.job接口类,并实现execute方法。
1 2 3 4 5 6 7 8 9 10 11 |
package com.pgw.quartz; import java.util.Date; import org.quartz.Job; import org.quartz.JobExecutionContext; import org.quartz.JobExecutionException; public class QuartzJob implements Job{ public void execute(JobExecutionContext arg0) throws JobExecutionException { System.out.println("Hello world !!!" + new Date()); } } |
QuartzCronTrigger 类:创建crontrigger类,继承CronTrigger类,实现 Serializable接口
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 |
package com.pgw.quartz; import org.quartz.CronTrigger; import java.io.Serializable; import java.text.ParseException; public class QuartzCronTrigger extends CronTrigger implements Serializable { private static final long serialVersionUID = 1L; public QuartzCronTrigger() { } public void setCronExpress(String corn, String name, String groupName) { try { this.setCronExpression(corn); this.setName(name); this.setGroup(groupName); } catch (ParseException e) { e.printStackTrace(); } } } |
QuartzMain 类
1、如果Scheduler没有设置名称,通过scheduler = factory.getDefaultScheduler();获取的Scheduler对象名称为DefaultQuartzScheduler。
2、Quartz可以设置一个Scheduler,然后在这个Scheduler下配置多对trigger和job度对象。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 |
package com.pgw.quartz; import org.quartz.CronTrigger; import org.quartz.JobDetail; import org.quartz.Scheduler; import org.quartz.impl.StdSchedulerFactory; public class QuartzMain { public static void main(String[] args) { // 创建一个jobDetail对象,将Job实际业务类放入jobDetail中 JobDetail jobDetail = new JobDetail("demo", "demo", QuartzJob.class); // 创建一个触发器 CronTrigger triggers = new QuartzCronTrigger(); try { // 设置触发器 名字 triggers.setName("demo"); // 设置触发器所属组 triggers.setGroup("demo"); // 设置触发时间cron表达式 triggers.setCronExpression("10 * * * * ?"); // 将jobDetail放入触发器中 triggers.setJobGroup("demo"); // 创建schedulerFactory对象 StdSchedulerFactory factory = new StdSchedulerFactory(); Scheduler scheduler = factory.getDefaultScheduler(); // Register the JobDetail and Trigger scheduler.scheduleJob(jobDetail, triggers); // 挂起定时线程 scheduler.start(); } catch (Exception ex) { ex.printStackTrace(); } } } |
HQL学习总结
hql语句是区分大小写的。
查询时候表名必须和实体类(po)相同,而查询的字段必须和实体类的属性名相同(而不是数据库的字段名)。
hql是面向对象的查询语句。
注意:在hql模糊查询中,在“%”的两旁要加上单引号,eg: LIKE ‘%value%’,否则会出错。
包含where子句的查询,使用”where 1=1″,如果后面的查询条件都不符合,会保证语法的正确性。
包含in子句的查询,使用”in(”, …)”,如果没有其他限定范围,同样也会保证语法的正确性。
在hql语句中“=”后面为string类型时,应写成 =’xxxx’ 形式,否则hql语句会报错。
在hql语句中escape ‘X’,会将 X 出现之后的字符视为非特殊字符。
在hql模糊查询中包含“”和“%”特殊字符,进行查询 1)“”替换为“/” like ‘%/..%’ espase ‘/’; 2)“%”替换为“/%” like ‘%/%..%’ espase ‘/’;
shell编程时要注意点
在shell编程时要注意一下几点:
赋值时“=”两边不能有空格。
测试条件[],在方括号内容的两侧都要加上空格。
echo 后的内容,系统一般都会认为为字符串。
list使用的低级错误
在本次的开发中,我们程序总是报内存溢出异常,后经过很长时间才分析出原因。发现后,感觉这是个十足的低级错误,现在写出来供大家阅读,以免再犯类似错误。
事件是这样的: 我的一个位同事为了获得表中数据的条数。通过hql语句,将数据库中所有数据查询出来,并将所有查询结果集放到一个list中。在开始使用的时候没有发现有什么问题。但是当数量上万以后,一运行程序就会立即报错–OutOfMemeryException。
估计讲到这里大家应该都明白怎么回事了。这个错误实在是太低级了。原本使用count就能解决的问题,他偏要将使用list.size获取数据条数。
总之,警示,误再犯此低级错了