2008年12月23日星期二

oracle sequence

1. 创建 Sequence

使用如下命令新建sequence(用户需要有CREATE SEQUENCE 或者CREATE ANY SEQUENCE权限):

CREATE SEQUENCE test_sequence
INCREMENT BY 1   -- 每次加的个数据
START WITH 1    -- 从1开始计数
NOMAXVALUE    -- 不设置最大值
NOCYCLE      -- 一直累加,不循环
CACHE 10 ;

[注意]
如 果设置了CACHE值,ORACLE将在内存里预先放置一些sequence,以使存取速度更快。cache里面的取完后,oracle自动再取一组到 cache。 但是,使用cache可能会跳号, 当遇到数据库突然异常down掉(shutdown abort),cache中的sequence就会丢失.
因此,推荐在create sequence的时候使用 nocache 选项。


2. 使用 sequence:

sequence.CURRVAL -- 返回 sequence的当前值
sequence.NEXTVAL -- 增加sequence的值,然后返回 sequence 值

[注意]
第一次NEXTVAL返回的是初始值;
随后的NEXTVAL会自动增加你定义的INCREMENT BY值,然后返回增加后的值。

CURRVAL 总是返回当前SEQUENCE的值,但是在第一次NEXTVAL初始化之后才能使用CURRVAL,否则会出错。
一次NEXTVAL会增加一次 SEQUENCE的值,所以如果你在同一个语句里面使用多个NEXTVAL,其值就是不一样的。


sequence 存储在数据字典中,存储于user_sequences表

LAST_NUMBER 为最终序列号,也就是sequence游标当前所在的位置。

//get sequence last_number

SELECT LAST_NUMBER FROM USER_SEQUENCES WHERE SEQUENCE_NAME=TEST_SEQNAME

// NEXTVAL 使游标指向下一位(增一或减一)

SELECT SEQNAME.NEXTVAL FROM USER_SEQUENCES 得到下一位游标的值


3. 修改 Sequence

用户必须拥有ALTER ANY SEQUENCE 权限才能修改sequence. 可以alter除start至以外的所有sequence参数.
如果想要改变start值,必须 drop sequence 再 re-create.

命令格式如下:

ALTER SEQUENCE test_sequence
INCREMENT BY 10
MAXVALUE 10000
CYCLE    -- 到10000后从头开始
NOCACHE ;

4. 删除 Sequence
DROP SEQUENCE order_seq;

2008年10月13日星期一

PDCA示意图

戴明循环

亦称PDCA循环。领导和管理的一种思想方法和基本工作程序,最初由美国统计学家戴明创造。

这里P(Plan)是计划;D(Do)是实施;C(Check)是检查;A(Action)是处理。即按照 计划-->实施-->检查-->处理-->计划 这样的程序,不断循环,周而复始。

这种方法的特点是

  • 四个阶段要求明确
    • 计划阶段要求制定方针、目标、活动安排、管理项目等;
    • 实施阶段要求严格按计划的额定目标和要求,扎扎实实地付诸实行;
    • 检查阶段要求检查执行的效果,并查明原因;
    • 处理阶段要求全面总结成败经验教训,形成标准化,使下一循环按标准化进行。
  • 各个单位都进行四个阶段的循环,相互促进,共同提高。
  • 不断循环,周而复始,循环一次,向更高的水平前进一步,而不是简单地原地踏步。

2008年8月27日星期三

在 Eclipse RCP 里使用 JFreeChart

JFreeChart 是个免费的纯Java图形类库。他使得开发人员在他们的程序里显示专业质量图形成为易事。想了解更多关于JFreeChart的信息,可以浏览下面的链接: http://www.jfree.org/jfreechart/

准备:先下载JFreeChart的类库吧。

第一步:新建一个叫“JFreeChartTest”的插件工程。可以用 "RCP application with a view"的模板进行创建.

第二步:创建一个叫“JFreeChartLib”的插件功能,将下载下来的类库增加到工程的build path里。
  • jcommon-1.0.10.jar


  • jfreechart-1.0.6.jar

  • jfreechart-1.0.6-swt.jar

  • swtgraphics2d.jar

上述jar文件的最新版本可能会有所更新。

第三步,将“JFreeChartLib”插件工程添加到“JFreeChartTest”工程的依赖库中。通过打开 JFreeChartTest 的 MANIFEST.MF 文件并选择 "Dependencies" 选项卡来进行设置。

第四步,编辑view代码。

代码参考http://www.javaread.com/topic/show/22

最后,运行,效果图如下:


2008年8月6日星期三

PowerDesigner12.5 破解



PowerDesigner是结合了下列几种标准建模技术的一款独具特色的建模工具集:业务流程建模、通过 UML 进行的应用程序建模以及市场占有率第一的数据建模,这些建模技术都是由功能强大的元数据管理解决方案提供支持的.

1.先下载安装软件
下载地址:http://download.sybase.com/eval/PowerDesigner/powerdesigner125_eval.exe

2.下载破解软件
下载地址:http://tnvbba.bay.livefilestore.com/y1pITUMg1VoSiejqCBNMSK8gfRr4gj-sOmSeAWo33ov6obOOY-qtbQk9b788WiNQy3XfatMda28aJ5d4r2Cu9Dp4g/Sybase.PowerDesigner.v12.5-Crack.zip?download

2.安装软件后,解压破解压缩包,将pdflm12.dll复制到PD 安装目录下。

3.打开PowerDesigner,菜单Tools -> License Parameters..

4.选择Standalone Seat - Local License

5.导入license.lic即可破解。

2008年3月19日星期三

设定windows服务的依存服务

设定windows服务的依存服务,如设定tomcat启动服务依存于Oracle服务

打开注册表编辑器,

HKEY_LOCAL_MACHINE\System\CurrentControlSet\Services\Your_Service
下建立一个REG_MULTI_SZ类型,名称为DependOnService的键值.
改键值内容为 当前服务需要依存的服务名称

2008年3月12日星期三

msn联系人乱码的解决办法

突然发现msn里的联系人,分组都成乱码了.网上搜了个解决办法如下:

1.关闭MSN Live Messenger
2.在运行窗口输入:regsvr32.exe inetcomm.dll
3.提示注册成功后到C:\Documents and Settings\当前登录用户名\Local Settings\Application Data\Microsoft 目录下删除Windows Live Contacts目录,重新启动MSN Live Messenger即可恢复正常中文名。

2008年3月2日星期日

安装Eclipse多国语言包

1.去官方网站下载语言包 http://download.eclipse.org/eclipse/downloads/
2.解压到文件目录,如c:\language
3.在eclipse目录下新建links目录,在links目录下新建文本文件language.link(可取任意名称),文件内容仅一行:

path=c:\\language

4.重启eclipse即可.

5.注意事项:
a.eclipse的版本不能高于语言包的版本
b.避免缓存干扰:启动eclipse加-clean参数

2008年2月24日星期日

maven 打包指定路径

在maven中,如何打包jar文件到指定目录?

sample,在pom.xml文件build部分中增加下面一行即可:

<build>

<directory>E:/eclipse/3.3/workspace/qualityone-rcp/lib</directory>

</build>

2008年2月23日星期六

RCP,Eclipse中UI程序的线程

类MyAction:

public class MyAction implements IRunnableWithProgress {

@Override
public void run(IProgressMonitor monitor) throws InvocationTargetException,
InterruptedException {
MyJob myJob = new MyJob("My Job ");
myJob
.addJobChangeListener(new MyJobChangeAdapter(Display
.getCurrent()));
myJob.setUser(true);
myJob.schedule();
monitor.subTask("Scheduled sending for recipient: ");
}

class MyJob extends Job {

public MyJob(String name) {
super(name);
}

@Override
protected IStatus run(IProgressMonitor monitor) {
try {
System.out.println("发呆中...");
Thread.sleep(15000);// 模拟一个需要10秒的工作
} catch (InterruptedException e) {
e.printStackTrace();
}
return Status.OK_STATUS;
}

}

class MyJobChangeAdapter extends JobChangeAdapter {

private final Display display;

/**
* @param display
*/
public MyJobChangeAdapter(Display display) {
super();
this.display = display;
}

/*
* (non-Javadoc)
*
* @see org.eclipse.core.runtime.jobs.JobChangeAdapter#done(org.eclipse.core.runtime.jobs.IJobChangeEvent)
*/
@Override
public void done(final IJobChangeEvent event) {
display.asyncExec(new Runnable() {
public void run() {
IStatus iStatus = event.getResult();
String errorMessage = iStatus.getMessage();

Shell shell = display.getActiveShell();
if (IStatus.OK == iStatus.getCode())
MessageDialog.openInformation(shell, event.getJob()
.getName(), "Mail Sent Successfully");
else
MessageDialog.openError(shell, "Error sending mail",
errorMessage);
}
});
}

}
}

测试类:ThreadTest

public class ThreadTest {

/**
* @param args
*/
public static void main(String[] args) {

final Display display = new Display();
Shell shell = new Shell(display);
shell.setSize(600, 400);
shell.setLayout(new FillLayout());

MyAction myAction = new MyAction ();
ProgressMonitorDialog progressMonitorDialog = new ProgressMonitorDialog (Display.getCurrent().getActiveShell() );

boolean separateThread = false;
boolean cancelable = true;
try {
progressMonitorDialog.run (separateThread, cancelable, myAction);
} catch (InvocationTargetException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}

shell.open();
while (!shell.isDisposed()) {
if (!display.readAndDispatch())
display.sleep();
}

display.dispose();


}

}

2008年2月18日星期一

RCP开发:如何在产品发布关于对话框中换行

在RCP开发完后,需要产品发布,如何提供在产品"关于"对话框中输入多行数据呢?

由于"关于"对话框中的数据是保存在plugin.xml里,XML是不支持回车换行的,找了个RCP的例子.发现在plugin.xml文件里换行符号用转义符代替(如下图所示)即可.

2008年2月1日星期五

免费eclipse国际化插件

eclipse的国际化插件,免费的哦.

可到 http://www.guh-software.de/jinto.html 下载

最新版本为
JInto 0.10.9 ZIP Archiv (for Eclipse 3.1.x und 3.2.x)
JInto 0.11.0 ZIP Archiv (for Eclipse 3.3.x)

2008年1月17日星期四

三亚游

14-16号去了趟三亚.在亚龙湾拍了几张照片,放上来,感受一下阳光大海沙滩的美丽.

蜈洲之岛

亚龙湾的游客

2008年1月9日星期三

同步Google Calendar到Thunderbird



Google Calendar老早就有了,可是每次需要登录网页才能记录日程安排,确实有些麻烦.
现在有一个办法可以同步Google Calendar到Thunderbird了.

具体操作如下:
一,Thunderbird部分
1.安装Thunderbird的日历扩展Lightning 0.7,点击下载,直接保存该扩展;
2.安装Thunderbird的Provider for Google Calendar 0.3.1扩展,点击下载,直接保存该扩展;
3.安装上述两扩展方式如图:


二,Google Calendar部分
(获取Google Calendar Private Address XML Feed)
1.打开Goolge Calendar帐户



2.复制Google Calendar Private Address XML Feed 地址


三,Thunderbird配置
1.File -> New -> Calendar…

2.加入地址

3.完成


更详细资料请参考

Stay in Sync with GCal and Thunderbird.

2008年1月8日星期二

GEF:导出到图片

GEF中编辑好图片后,如何保存成图片呢?

以下是Action的代码:

private class ExportImageAction extends Action {

private final Log log = LogFactory.getLog(getClass());

/**
* Constructor
*/
public ExportImageAction() {
setText("导出图片到本地");
setHoverImageDescriptor(ImagesContext
.getImageDescriptor(ImagesContext.SAVE));
}

@Override
public void run() {
FileDialog dialog = new FileDialog(Util.getShell(), SWT.SAVE);
dialog.setFilterNames(new String[] { "PNG(*.png)" });
dialog.setFilterExtensions(new String[] { "*.png", "*.*" });
String fileName = dialog.open();
DiagramEditor editor = (DiagramEditor) getPage().getActiveEditor();
RootEditPart rootPart = editor.getViewer().getRootEditPart();
IFigure figure = ((ScalableRootEditPart) rootPart)
.getLayer(ScalableRootEditPart.PRINTABLE_LAYERS);
byte[] data = createImage(figure, SWT.IMAGE_PNG);
try {
FileOutputStream fos = new FileOutputStream(fileName);
fos.write(data);
fos.close();
MessageDialog.openInformation(editor.getSite().getShell(),
"导出", "图形已经导出到 " + fileName);
} catch (IOException e) {
log.warn("导出图片出错", e.fillInStackTrace());
}
}

private byte[] createImage(IFigure figure, int format) {
Rectangle r = figure.getBounds();
ByteArrayOutputStream result = new ByteArrayOutputStream();
Image image = null;
GC gc = null;
Graphics g = null;
try {
image = new Image(null, r.width, r.height);
gc = new GC(image);
g = new SWTGraphics(gc);
g.translate(r.x * -1, r.y * -1);
figure.paint(g);
ImageLoader imageLoader = new ImageLoader();
imageLoader.data = new ImageData[] { image.getImageData() };
imageLoader.save(result, format);
} finally {
if (g != null) {
g.dispose();
}
if (gc != null) {
gc.dispose();
}
if (image != null) {
image.dispose();
}
}
return result.toByteArray();
}

}

2008年1月3日星期四

regex常用正则表达式

正则表达式用于字符串处理、表单验证等场合,实用高效。现将一些常用的表达式收集于此,以备不时之需。

匹配中文字符的正则表达式: [\u4e00-\u9fa5]
评注:匹配中文还真是个头疼的事,有了这个表达式就好办了

匹配双字节字符(包括汉字在内):[^\x00-\xff]
评注:可以用来计算字符串的长度(一个双字节字符长度计2,ASCII字符计1)

匹配空白行的正则表达式:\n\s*\r
评注:可以用来删除空白行

匹配HTML标记的正则表达式:<(\S*?)[^>]*>.*?|<.*? />
评注:网上流传的版本太糟糕,上面这个也仅仅能匹配部分,对于复杂的嵌套标记依旧无能为力

匹配首尾空白字符的正则表达式:^\s*|\s*$
评注:可以用来删除行首行尾的空白字符(包括空格、制表符、换页符等等),非常有用的表达式

匹配Email地址的正则表达式:\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*
评注:表单验证时很实用

匹配网址URL的正则表达式:[a-zA-z]+://[^\s]*
评注:网上流传的版本功能很有限,上面这个基本可以满足需求

匹配帐号是否合法(字母开头,允许5-16字节,允许字母数字下划线):^[a-zA-Z][a-zA-Z0-9_]{4,15}$
评注:表单验证时很实用

匹配国内电话号码:\d{3}-\d{8}|\d{4}-\d{7}
评注:匹配形式如 0511-4405222 或 021-87888822

匹配腾讯QQ号:[1-9][0-9]{4,}
评注:腾讯QQ号从10000开始

匹配中国邮政编码:[1-9]\d{5}(?!\d)
评注:中国邮政编码为6位数字

匹配身份证:\d{15}|\d{18}
评注:中国的身份证为15位或18位

匹配ip地址:\d+\.\d+\.\d+\.\d+
评注:提取ip地址时有用

匹配特定数字:
^[1-9]\d*$    //匹配正整数
^-[1-9]\d*$   //匹配负整数
^-?[1-9]\d*$   //匹配整数
^[1-9]\d*|0$  //匹配非负整数(正整数 + 0)
^-[1-9]\d*|0$   //匹配非正整数(负整数 + 0)
^[1-9]\d*\.\d*|0\.\d*[1-9]\d*$   //匹配正浮点数
^-([1-9]\d*\.\d*|0\.\d*[1-9]\d*)$  //匹配负浮点数
^-?([1-9]\d*\.\d*|0\.\d*[1-9]\d*|0?\.0+|0)$  //匹配浮点数
^[1-9]\d*\.\d*|0\.\d*[1-9]\d*|0?\.0+|0$   //匹配非负浮点数(正浮点数 + 0)
^(-([1-9]\d*\.\d*|0\.\d*[1-9]\d*))|0?\.0+|0$  //匹配非正浮点数(负浮点数 + 0)
评注:处理大量数据时有用,具体应用时注意修正

匹配特定字符串:
^[A-Za-z]+$  //匹配由26个英文字母组成的字符串
^[A-Z]+$  //匹配由26个英文字母的大写组成的字符串
^[a-z]+$  //匹配由26个英文字母的小写组成的字符串
^[A-Za-z0-9]+$  //匹配由数字和26个英文字母组成的字符串
^\w+$  //匹配由数字、26个英文字母或者下划线组成的字符串
评注:最基本也是最常用的一些表达式