随笔-77  评论-5  文章-2  trackbacks-0
  2009年5月1日
class Square{
public:
 Square(int x ) :value(x*x){
 }

Square(const Square& other) = delete;//rule 1

const Square & operator = (const Square& other) == delete;//rule 2
const Square & operator = (Square&& other) = delete;//rule3 

..
}

Square s = 9; //因为s没有初始化,会先用9 调用构造函数 Square(int x ) , 然后调用Square(const Square& other),和rule1 违背
Square s2(8);
 s= s2;//对应rule 2
 s= Square(9);//对应 rule3 
posted @ 2019-12-31 21:11 huohuo 阅读(1041) | 评论 (0)编辑 收藏
其实一直想学ruby,总是拖拖拉拉推了几年。 很多ruby的教材要么老厚一本 要么是东一榔头西一斧头,逻辑性不清楚 ruby语法还没说清楚就上rails了 这个教材挺好。 今天才发现argument 是实参,parameter是形参
posted @ 2014-07-07 22:20 huohuo 阅读(230) | 评论 (0)编辑 收藏
小新看到妈妈用订书机订了一个盒子,他就从打印机上面拿了几张a4纸,钉了一个像盒子的东西,当作他的百宝箱,把他的一些零零碎碎的东西放到他的百宝箱中。 有一天他看到了妈妈的首饰盒,他觉得很漂亮,就和妈妈说:妈妈,我把你这个盒子里面的东西放到我的那个百宝箱里面,你这个盒子给我当百宝箱吧。 妈妈当然不同意。小新很希望要个百宝箱,爸爸就问他:“你需要一个多大的百宝箱?” 小新比划了一个大小,他希望大一点,能装很多东西。爸爸问他是不是希望箱子能有很多分隔? 小新说不要分隔,但是百宝箱要有锁。 爸爸明白了---你就是要个能锁住的箱子嘛,我给你找个皮箱,带密码锁的。 第二天,爸爸上班回来,发现他平时用的笔记本电脑被小新锁在他的"新百宝箱"----密码锁皮箱里面了,密码是小新设的。 爸爸不知道密码,打不开皮箱,爸爸就和小新说:"帮爸爸把电脑拿出来,爸爸要给你查一个睡觉前讲的故事,不然今天就没故事听了"。 小新说:“你用手机也可以查的嘛,别以为我不知道”
posted @ 2014-01-20 21:49 huohuo 阅读(209) | 评论 (0)编辑 收藏
1 解析utf-8的中文字符问题,我修改了 ReportTask类里面的一个方法,增加了一个getJava().setVmArgs("-Dfile.encoding=utf-8")
2.覆盖率出不了数据   一方面注意制定datafile,把cubertura-instrument和cobertura-report的datafile设置为一个,另外junit里面也要设置一个系统属性,制定cubertura的datafile属性.  不制定datafile时,可能生成文件在当前运行ant的目录.但是我们ant任务中的junit测试任务,可能会使用不同的目录来作工作路径.这样会导致datafile不一致.

另外一个是要记得将javac 任务的debug="yes" ,因为只有debug =yes时,编译的代码才带有行信息,能显示覆盖.  当然常见的问题是junit的classpath中的instrument class目录放到原来被测class之前.




posted @ 2013-08-18 22:37 huohuo 阅读(479) | 评论 (0)编辑 收藏
下载putty的安装版本,安装之后有一个plink pscp程序。
plink程序负责调用ssh命令
pscp负责上传文件。

plink -l user -pw pass   hostname

但是因为plink会提示是否要保存密码,不能保证自动批处理运行,此时利用管道的能力来输入提示的结果

echo Y >yes.txt
plink -l user -pw pass   hostname <yes.txt
posted @ 2012-03-04 06:31 huohuo 阅读(583) | 评论 (0)编辑 收藏
/Files/lijinglin/storm.pdf
posted @ 2011-12-21 01:27 huohuo 阅读(277) | 评论 (0)编辑 收藏
/Files/lijinglin/zookeeper.ppt
posted @ 2011-12-21 00:33 huohuo 阅读(314) | 评论 (0)编辑 收藏
kafka pdf

/Files/lijinglin/F_1330_Narkhede_Kafka.pptx
posted @ 2011-12-20 22:53 huohuo 阅读(304) | 评论 (0)编辑 收藏
/Files/lijinglin/stormsrc.rar
posted @ 2011-12-19 02:15 huohuo 阅读(234) | 评论 (0)编辑 收藏

zookeeper集群安装

测试环境redhat5.5:
vmware建两台虚拟机(btw,似乎双核系统只能建俩,3个就死掉了)
192.168.229.129
192.168.229.130


下载2011年12月15日的最新zookeeper
加压到
/opt/zookeeper-3.4.0/
配置/opt/zookeeper-3.4.0/conf/zoo.cfg
可以把那个例子考过来
Java代码 复制代码 收藏代码
  1. # The number of milliseconds of each tick   
  2. tickTime=2000  
  3. # The number of ticks that the initial    
  4. # synchronization phase can take   
  5. initLimit=10  
  6. # The number of ticks that can pass between    
  7. # sending a request and getting an acknowledgement   
  8. syncLimit=5  
  9. # the directory where the snapshot is stored.   
  10. do not use /tmp for storage, /tmp here is just    
  11. # example sakes.   
  12. dataDir=/opt/zookeeper-3.4.0/data/zookeeper   
  13. dataLogDir=/opt/zookeeper-3.4.0/data/log   
  14. # the port at which the clients will connect   
  15. clientPort=2181  
  16. #   
  17. # Be sure to read the maintenance section of the    
  18. # administrator guide before turning on autopurge.   
  19. #   
  20. # http://zookeeper.apache.org/doc/current/zookeeperAdmin.html#sc_maintenance   
  21. #   
  22. # The number of snapshots to retain in dataDir   
  23. #autopurge.snapRetainCount=3  
  24. # Purge task interval in hours   
  25. # Set to "0" to disable auto purge feature   
  26. #autopurge.purgeInterval=1  
  27. server.1=192.168.229.129:2888:3888  
  28. server.2=192.168.229.130:2888:3888  

修改/opt/zookeeper-3.4.0/bin/zkServer.sh
Java代码 复制代码 收藏代码
  1. status)   
  2.     # -q is necessary on some versions of linux where nc returns too quickly, and no stat result is output   
  3.     #STAT=`echo stat | nc -q 1 localhost $(grep "^[[:space:]]*clientPort" "$ZOOCFG" | sed -e 's/.*=//'2> /dev/null| grep Mode`   
  4.     STAT=`echo stat | nc localhost $(grep "^[[:space:]]*clientPort" "$ZOOCFG" | sed -e 's/.*=//'2> /dev/null| grep Mode`  

以上这些多台机器一样

log和data都在dataDir下面
如果找不到log了用大招:
ps -ef|grep zookeeper
ls -l /proc/123123/fd
其中有一个是log
然后dataDir建立一个文件myid
在192.168.229.129上
echo 1 >/opt/zookeeper-3.4.0/data/zookeeper/myid
在192.168.229.130上
echo 2 >/opt/zookeeper-3.4.0/data/zookeeper/myid
对应zoo.cfg里面的
注意一定是数字


然后zkServer.sh start 
启动
zkServer.sh status
看状态
echo ruok|nc localhost 2181         
//are you ok?
echo dump|nc localhost 2181
echo stat|nc localhost 2181
echo srst|nc localhost 2181
zkServer.sh stop
posted @ 2011-12-16 03:48 huohuo 阅读(1318) | 评论 (0)编辑 收藏

 

public class Util {
 final static int LINE_COUNT = 16;
 final static int WORD_COUNT = 2;
 public static StringBuffer toHex(byte b)
 {
  byte factor = 16;
  int v = b & 0xff;//去掉byte转换之后的负数部分。
  byte high = (byte)( v / factor);
  byte low = (byte)(v % factor);
  StringBuffer buf = new StringBuffer();
  buf.append(toHexLow(high)).append(toHexLow(low));
  return buf;
 }
 private static char toHexLow(byte b)
 {
  if(b > 16 || b < 0 )
  {
   throw new IllegalArgumentException("inpt parameter should less than 16 and greater than 0");
  }
  if(b < 10){
   return (char)('0' + (char)b);
  }
  else{
    return (char)('A' + (b-10));

  }
 }
 
 public static StringBuffer toHex(int val)
 {
  StringBuffer buf = toHex((byte)(val >>24 & 0xff)).append(toHex((byte)(val>>16&0xff)));
  return buf.append(toHex((byte)(val>>8&0xff))).append(toHex((byte)(val & 0xff)));
 }
 
 /**
  * 打印二进制数组
  * @param arr
  * @param off
  * @param len
  */
 public static void printBytes(byte [] arr,int off,int len)
 {
  if(arr == null || len <= 0 || off <0 || off + len > arr.length){
   return;
  }
  
  int count = 0;
  
  for(int i = off; count < len; ++i)
  {
   System.out.print(toHex(arr[i]));
   
   ++ count;
   if(count% WORD_COUNT == 0)
   {
    System.out.print(' ');
   }
   if(count % LINE_COUNT == 0)
   {
    System.out.println();
   }
  }
 }
 
 public static void main(String[] args) {
  byte[] arr = new byte[256];
  for(int i = 0; i < 256;++i )
  {
   
   arr[i] = (byte)i;
   
  }
  
  printBytes(arr,0,256);
  printBytes(arr,240,16);
  
  System.out.println(toHex(1));
  System.out.println(toHex(0xffffffff));
  System.out.println(toHex(0xeeffaacc));
 }
}




另外c++写好的小端序的int数据,用java读入如此处理
 private static int convertInt(byte[]  arr)
 {
  if(arr == null || arr.length != 4)
  {
   throw new IllegalArgumentException("bytes array error");
  }
  int val = (arr[0] & 0xff) | (arr[1] & 0xff)<<8 | (arr[2] & 0xff)<<16 | (arr[3]&0xff)<<24;
  return val;
 }


posted @ 2011-11-02 21:36 huohuo 阅读(5370) | 评论 (0)编辑 收藏
1.修改当前的hostname可以用
hostname  myname
此时只是修改了内存内部的,下次启动又恢复了
2.机器在启动的时候会调用/etc/rc.d/boot.localnet
脚本看后面的附录,这个脚本会判断当前的$HOSTNAME变量是否设置,没有设置就会读取/etc/HOSTNAME
来设置主机名。
3.因此要修改hostname,
 3.1 修改/etc/HOSTNAME文件
 3.2 修改当前的$HOSTNAME变量
 3.3 停掉/etc/rc.d/boot.localnet
 3.4 启动 /etc/rc.d/boot.localnet
因此执行脚本如下:
 export HOSTNAME=myname
 echo $HOSTNAME>/etc/HOSTNAME
  /etc/rc.d/boot.localnet stop
 /etc/rc.d/boot.localnet start


附录:/etc/rc.d/boot.localnet

case "$1" in
  start)
        # clean up old yp bindings
        rm -f /var/yp/binding/*.[12]

        #
        # set hostname and domainname
        #
        XHOSTNAME=""
        test -f /etc/HOSTNAME && {
            read XHOSTNAME < /etc/HOSTNAME
        }
        test -n "$HOSTNAME" -a "$HOSTNAME" != '(none)' && {
            echo Using boot-specified hostname \'${HOSTNAME}\'
            XHOSTNAME="$HOSTNAME"
        }
        test -n "$XHOSTNAME" && {
            echo -n Setting up hostname \'${XHOSTNAME%%.*}\'
            hostname ${XHOSTNAME%%.*}
            rc_status -v -r
        }

        XDOMAINNAME=""
        test -f /etc/defaultdomain && {
            read XDOMAINNAME < /etc/defaultdomain
        }
        test -n "$XDOMAINNAME" && {
            echo -n Setting up NIS domainname \'$XDOMAINNAME\'
        }
        domainname "$XDOMAINNAME"
        test -n "$XDOMAINNAME" && {
        rc_status -v -r
                         


posted @ 2011-10-27 22:21 huohuo 阅读(16353) | 评论 (3)编辑 收藏
http://www.infoq.com/cn/articles/hadoop-config-tip

http://hadoop.apache.org/common/docs/r0.19.2/cn/cluster_setup.html

http://wenku.baidu.com/view/be021f3667ec102de2bd8964.html

这个装完带验证url
http://wenku.baidu.com/view/373ed21fb7360b4c2e3f64ce.html
posted @ 2011-10-25 06:50 huohuo 阅读(177) | 评论 (0)编辑 收藏
/Files/lijinglin/LINUX_SHELL.part2.rar
/Files/lijinglin/LINUX_SHELL.part1.rar
/Files/lijinglin/diveintopython3.rar
posted @ 2011-10-25 06:45 huohuo 阅读(171) | 评论 (0)编辑 收藏
1.安装suse
装好vmware workstation8,跑到open suse,下载suse11的光盘iso文件,将iso文件映射到vmware的光驱做安装。
2.安装vmwaretools,用root用户执行
vmware安装目录中的linux.iso中带有的VMwareTools*.gz
执行vmware-install.pl
一路回车,中途碰到问题,提到找不到kernel header文件,
The path "" is not a valid path to the 2.6.37-1-1.2-desktop kernel

参照网上文件
安装了kernel-devel ,还是碰到问题,,又安装了kernel-desktop-devel*.rpm
再试用 rpm -ql kernel-desktop-devel,
发现这个包的文件都安装的 /usr/src/linux-2.6.37.1-1.2-obj/
下面,于是我采用这个路径/usr/src/linux-2.6.37.1-1.2-obj/i586/desktop/include
结果安装成功。这个vmwaretools主要是为了提供一个和主操作系统共享文件目录的作用吧。
安装起来还是比较费劲的。
posted @ 2011-10-25 05:51 huohuo 阅读(2257) | 评论 (0)编辑 收藏
 透明gif动画读写伸缩例子

今天找了第三方的代码,然后自己修改了部分,实现了透明动画gif的读写,jdk 5下测试通过。

虽然jdk6支持gif的读写,但是很多系统没有升级到jdk6,不可能为了一个gif读写伸缩功能就要升级到jdk6.

这个例子里面使用了开源的gifdecoder animatedgifencoder。
开源的gifdecoder有个bug,透明色经常被它变为黑色,这样很不好。

另外GifUtil类里面有伸缩gif图的例子,有些人图伸缩之后存会gif会出现颜色变多了,超过gif的256色,
因此伸缩也是有特别注意的地方。


具体看代码吧,没有太多空解释
posted @ 2009-09-10 19:53 huohuo 阅读(2120) | 评论 (0)编辑 收藏

李运新 發表相片:

蹲下玩


文章来源:http://www.flickr.com/photos/liyunxin/3409487358/
posted @ 2009-05-01 10:57 huohuo 阅读(113) | 评论 (0)编辑 收藏

李运新 發表相片:

这是什么


文章来源:http://www.flickr.com/photos/liyunxin/3408678473/
posted @ 2009-05-01 10:57 huohuo 阅读(71) | 评论 (0)编辑 收藏

李运新 發表相片:

在朝阳一巷的工商一行宿舍

在朝阳一巷的工商一行宿舍


文章来源:http://www.flickr.com/photos/liyunxin/3408678585/
posted @ 2009-05-01 10:57 huohuo 阅读(79) | 评论 (0)编辑 收藏

李运新 發表相片:

在朝阳一巷的工商一行宿舍

在朝阳一巷的工商一行宿舍


文章来源:http://www.flickr.com/photos/liyunxin/3409487680/
posted @ 2009-05-01 10:57 huohuo 阅读(88) | 评论 (0)编辑 收藏

李运新 發表相片:

唔...

在朝阳一巷的工商一行宿舍


文章来源:http://www.flickr.com/photos/liyunxin/3409487798/
posted @ 2009-05-01 10:57 huohuo 阅读(83) | 评论 (0)编辑 收藏

李运新 發表相片:

在路上


文章来源:http://www.flickr.com/photos/liyunxin/3408678979/
posted @ 2009-05-01 10:57 huohuo 阅读(93) | 评论 (0)编辑 收藏

李运新 發表相片:

锦母角的船上


文章来源:http://www.flickr.com/photos/liyunxin/3409488100/
posted @ 2009-05-01 10:57 huohuo 阅读(86) | 评论 (0)编辑 收藏

李运新 發表相片:

锦母角的船上


文章来源:http://www.flickr.com/photos/liyunxin/3408679279/
posted @ 2009-05-01 10:57 huohuo 阅读(76) | 评论 (0)编辑 收藏

李运新 發表相片:

锦母角的船上

锦母角的船上,和奶奶在一起


文章来源:http://www.flickr.com/photos/liyunxin/3409488420/
posted @ 2009-05-01 10:57 huohuo 阅读(76) | 评论 (0)编辑 收藏

李运新 發表相片:

锦母角的船上

锦母角的船上


文章来源:http://www.flickr.com/photos/liyunxin/3408679495/
posted @ 2009-05-01 10:57 huohuo 阅读(75) | 评论 (0)编辑 收藏

李运新 發表相片:

红沙蛋家鱼排

和爸爸妈妈在一起


文章来源:http://www.flickr.com/photos/liyunxin/3408680885/
posted @ 2009-05-01 10:57 huohuo 阅读(647) | 评论 (1)编辑 收藏

jad -debug -o -r -sjava -dsrc **/*.class

由于jad不支持新版本的class文件,使用
-debug ,可以强制对新版本的class文件反编译

-d是指定目标路径

**/*.class 表示当前目录下所有class文件

xx/**/*.class 表示xx目录下所有class文件

 

jad的网站

http://www.kpdus.com/jad.html

 

新版jad下载路径

http://www.kpdus.com/jad/winnt/jadnt158.zip

 

 

今天转换了oracle adf的代码,好多编译不过,郁闷,写jad的后来不出版本了啊

oracle也垃圾,说是公开代码了,都没有地方下载

 

 

 


文章来源:http://stocknewbie.bokee.com/viewdiary.11784700.html
posted @ 2009-05-01 10:52 huohuo 阅读(231) | 评论 (0)编辑 收藏

最近下了oracle adf的 source code,想编译一下javadoc,用eclipse生成,搞出来out of memory,

于是翻了一下ant 的帮助,做了一个build.xml,设置了Xmx

本来工作正常得,删除了一点东西,没有测试,先贴着吧。

【adf 得代码还是挺难找的,终于在老外的一个blog上找到,是oracle给apache的,和 jdeveloper 10.1.3上的还是有点差别】

 

<project name="name of project" default="javadoc" basedir=".">


 <property name="adf-api.home"      value="E:/doc/oracle/apache-drop/adf-faces/adf-faces-api"/>
 <property name="adf-impl.home"      value="E:/doc/oracle/apache-drop/adf-faces/adf-faces-impl"/>
 <property name="dest.home"      value="E:/doc/oracle/apache-drop"/>

 

 

 

  <path id="doc.src.path">


   <pathelement path="${adf-api.home}/src/main/java"/>
     
   <pathelement path="${adf-api.home}/target/maven-i18n-plugin/main/java"/>
     
   <pathelement path="${adf-api.home}/target/maven-xrts-plugin/main/java"/>
     
   <pathelement path="${adf-api.home}/target/maven-faces-plugin/main/java"/>
     
    <pathelement path="${adf-impl.home}/src/main/java"/>
     
   <pathelement path="${adf-impl.home}/target/maven-javascript-plugin/main/resources"/>
     
   <pathelement path="${adf-impl.home}/target/maven-xrts-plugin/main/java"/>
     
   <pathelement path="${adf-impl.home}/target/maven-i18n-plugin/main/java"/>
     
   <pathelement path="${adf-impl.home}/target/maven-i18n-plugin/main/javascript"/>
     
   <pathelement path="${adf-impl.home}/target/maven-faces-plugin/main/java"/>
         
 </path>

  <path id="classes.path" >


  </path>


  <target name="javadoc"
   description="Create Javadoc API documentation">

    <mkdir          dir="${dest.home}/docs/api"/>
    <javadoc sourcepathref="doc.src.path" packagenames="oracle.*"
                destdir="${dist.home}/docs/api"
          maxmemory="200M">

   


    </javadoc>

  </target>


</project>


文章来源:http://stocknewbie.bokee.com/viewdiary.11971386.html
posted @ 2009-05-01 10:52 huohuo 阅读(823) | 评论 (0)编辑 收藏

早就听说google的map功能,今天在地图上找到把自己居住和上班的地方

找到了自己的卫星图,真的很有意思,这个图还是比较老的,图中科技园的中兴还在施工

 

http://maps.google.com/maps?f=q&hl=zh-CN&q=china&ie=UTF8&t=k&om=1&ll=22.536976,113.937063&spn=0.009711,0.021458

 

纬度 22。53  经度  113。93 属于热带,在北京西南面

 

 

两个软件

javascript plus,上面带了和js相关的dom,js core reference js client guide 之类的帮助。

编辑器有code insight 功能

 

dom inspector 可以查看页面上某个元素的属性,style,作为ie的插件,可以用鼠标点选控件来知道其中的dom对象属性和html代码

 

 


文章来源:http://stocknewbie.bokee.com/viewdiary.12043254.html
posted @ 2009-05-01 10:52 huohuo 阅读(156) | 评论 (0)编辑 收藏

目前使用oracle adf 框架 10.1.3 版本

1 adf 的源代码 (交付给apache 的)


http://people.apache.org/~bdudney/apache-drop.zip

是从http://www.orablogs.com/jjacobi/ 上面看到了

 

2. 其实我把 adf-faces-api  adf-faces-impl.jar 用jad 解码出来了,反正许多编译不过,里面的代码版本和apache的版本还不是一致的

 

3. apache 的myface 正在改adf-faces 的代码,可以去他们的svn上取,取出来的结构和原来oracle的区别很大。

怀疑下一个版本的jdeveloper ,如果基于myface的adf 作表示层的话,兼容性很难保证。

 

4。 adf 空间里面的类层次比较复杂,oracle原来是使用uix机制,为了遵守jsf规范使用jsf绘制的时候,很多处理还是有uix概念。我怀疑如果重新设计的话,adf 完全可以简单得多。不过目前oracle adf 控件同时支持pda,desktop,

是了不起的,虽然没有尝试过他的pda版本

 

5 adf-facs-impl.jar!META-INF/faces-config.xml 定义了UIComponent 和Render的对应关系。

因此如果要修改adf控件的绘制器时,可以干掉jar包下的faces-config.xml,在自己的代码路径建立 /META-INF/faces-config.xml  ,修改这个文件来修改控件对应的绘制器

 

唉,混了这么多年,还在表示层打滚,应该看看工作流了。

 

 

 

 

 


文章来源:http://stocknewbie.bokee.com/viewdiary.12098419.html
posted @ 2009-05-01 10:52 huohuo 阅读(630) | 评论 (0)编辑 收藏

上周折腾了几天,oracle workflow 2.6.3没有装好,这周和zg交流了一下,发现我没有看installation guide ,他的中间层装对了,我的数据库装对了,今天终于整合出来了,虽然他是linux,我是winxp

 

经验如下:

workflowserver 2.6.3 依赖 oracle db,oracle db companion cd.oracle httpserver standalone 9.04,

 

1.装10g dbserver ,oracle 10g db server 字符集选用中文的UTF-8编码方式,不能用zhs16gbk,因为
工作流配置程序WorkflowCA.jar中写死了zhs对应的字符集是utf8,要出现中文,就得用utf8


2.安装dbserver 的伴侣盘oracle 10 g companion cd ,安装第一项.装了这个才有一些什么owa_util之类的东西,大概是oracle web agent吧

 

3.装完dbserver之后就可以装workflowserver 的服务器部分,装到10g服务器下

 

4.装完之后,数据库菜单下面有个 workflow configuration assistant,按照安装指南设置一下参数。


5. oracle application server 里面的 httpserver ,需要放到不在数据库的那个oracle_home,我装在d:\oracleApache. 这个httpserver ,将一些请求,转成对数据库的pl/sql procedure的请求,由plsql代码生成网页

 

(其实伴侣盘里面也是有oracle http server ,我刚开始没有配置好,也许也是可以的,后来就选zg装成功的as中的httpserver)

 

6.安装workflowserver 的middletier 到 httpserver所在的oraclehome

 

需要修改dads.conf

<Location /pls/wf>
  SetHandler pls_handler
  Order deny,allow
  Allow from all
  AllowOverride None
  PlsqlDatabaseConnectString 10.16.33.178:1521:ORCL
  PlsqlAuthenticationMode Basic
  PlsqlDefaultPage wfa_html.home

  PlsqlNLSLanguage      "SIMPLIFIED CHINESE_CHINA.UTF8"
</Location>

 

7. windows xp 下启动httpserver时,

a.网上邻居-》本地连接-》属性-》高级—》Wins标签-》去掉启用LMhosts查询
前的勾就可以了.

b 控制面板-》windows防火墙-》高级标签-》网络连接设置-》设置-》勾选安
全Web服务器(HTTPS)"选项,按两次"确定"即可

c。关闭一些vpn之类的软件,一些网络程序,如skype 时才能正常启动httpserver

启动httpserver失败时,请查看
D:\oraApache\Apache\Apache\logs\error_log

和D:\oraApache\opmn\logs\HttpServer~1


如果D:\oraApache\Apache\Apache\logs\error_log显示
[Tue Jul 18 16:27:33 2006] [crit] (10022)提供了一个无效的参数。:
setup_inherited_listeners: WSASocket failed to open the inherited socket.

表示端口被占用,检查是否启动了其他特别的vpn软件,或者软件占用了apache server的端口,使用有其他网络程序干扰.
netstat -a 和netstat -ab

8.访问页面 http://localhost:7777/pls/wf/wfa_html.home

 

9.后记: 其实这个版本有bug,在有个脚本里面有 select to_number('10g') from ....

会提示错误,windows下面,这个错误似乎不影响,可以一直装下去,linux下面似乎要改掉。


文章来源:http://stocknewbie.bokee.com/viewdiary.12103536.html
posted @ 2009-05-01 10:52 huohuo 阅读(1028) | 评论 (0)编辑 收藏

今天看cctv-12的道德观察,里面讲一些百姓英雄。在桂林发生一起抢包事件,一个女孩背着包在街上走,此时一个小偷从后面冲过来,小偷抢了包就走,女孩在后面追,大叫抓小偷,追了一阵,女孩体力不支,越追越远。此时前面有两个女孩,正在散步,小偷从她们前面冲过去了,这是其中一个叫邓树花,听到抓小偷,于是追了出去,小偷本来以为甩掉了失主,打开包的拉链一看,就一个老式的三星旧手机,不值什么钱,这个时候后面有又人追来,赶紧跑,后面的mm紧追不舍,他就把包扔了,心想不会追吧,结果女孩仍然在追,(女孩事后说,我当时好像看见他丢了点什么,但不知道是包),女孩追上去,抓住了小偷的衣领。小偷掏出刀:放了我吧,再不放,我就捅死你,女孩当时一直不肯放手(画外音说不管小偷怎样求饶,邓树花就不肯放) 邓树花后来说:我当时看到刀,吓懵了,都忘记自己还抓着他的衣领。小偷往她手上割了一刀,她当时感觉麻麻的,没有放手,又割了两刀,没有用,一刀捅在手臂。邓树花没有力气了,就拉不住小偷,摔到在地上,小偷逃走了,这是邓树花大叫抓小偷,几个在附近的酒吧门口的人发现了,两个送邓树花去了医院,三个追小偷去了(他们说女人都抓小偷,我们怎么能不追呢),追了一阵,前面也有人拦住小偷,小偷拿刀示威,同时求饶,要他们放了他,此时围住他的人说:你如果就是偷东西还罢了,还拿刀伤人,一定不能放,最后搏斗,抓住小偷,一人负伤。

我和lp看了觉得好玩,这位女英雄很真实,很有趣。

 


文章来源:http://stocknewbie.bokee.com/viewdiary.13204052.html
posted @ 2009-05-01 10:52 huohuo 阅读(99) | 评论 (0)编辑 收藏
     摘要:    DHTML,Table标签,固定行头,固定列头列   <html> <head> <!--固定行列头,曲滨200608--> <style type="text/css"> <!-- body,table, td, a { font:9pt; }   /...  阅读全文
posted @ 2009-05-01 10:52 huohuo 阅读(405) | 评论 (0)编辑 收藏

最近刚结婚,我妈来了,丈母娘来了,这几天,发现自己很傻。以前以为我妈是很直爽的人,最近也发现妈妈也是有点精明的。岳母更是非常了得的人。 老婆一直以为岳父已经比较糊涂,头脑不清楚,岳母也不是那么精明了。这次来了,才知道,岳父其实也很精的。我们年轻一代,其实不如他们,具体事情就不说了。(老婆说,我这口气,好像是以前认为比他们精明,其实老婆以为岳父母糊涂,就是自己以为自己清楚)。

具体事情就不说了,记录以下以前看到的一个段子

 

My Father

When I was:
Four years old: My daddy can do anything.
Five years old: My daddy knows a whole lot.
Six years old: My dad is smarter than your dad.
Eight years old: My dad doesn't know exactly everything.
Ten years old: In the olden days, when my dad grew up, things were sure different.
Twelve years old: Oh, well, naturally, Dad doesn't know anything about that. He is too old to remember his childhood.
Fourteen years old: Don't pay any attention to my dad. He is so old-fashioned.
Twenty-one years old: Him? My Lord, he's hopelessly out of date.
Twenty-five years old: Dad knows about it, but then he should, because he has been around so long.
Thirty years old: Maybe we should ask Dad what he thinks. After all, he's had a lot of experience.
Thirty-five years old: I'm not doing a single thing until I talk to Dad.
Forty years old: I wonder how Dad would have handled it. He was so wise.
Fifty years old: I'd give anything if Dad were here now so I could talk this over with him. Too bad I didn't appreciate how smart he was. I could have learned a lot from him.

Writer Unknown

中文翻译:

我的爸爸

当我四岁的时候:爸爸可以做任何事。
当我五岁的时候:爸爸知道的很多。
当我六岁的时候:我爸爸比你爸爸聪明。
当我八岁的时候:爸爸并不是知道每一件事。
当我十岁的时候:在爸爸成长的旧日里,事情和现在完全不同。
当我十二岁的时候:哦,很显然,爸爸对于那件事什么也不知道。他太老了,回忆不起自己的童年了。
当我十四岁的时候:别管我爸爸。他太守旧了。
当我二十一岁的时候:他?上帝,他是无可救药地过时了。
当我二十五岁的时候:爸爸对此了解,但是这是他应该了解的,因为他已经经历了这么多。
当我三十岁的时候:也许我们该问问爸爸他是怎么想的。毕竟他有很多经验。
当我三十五岁的时候:除非我和爸爸谈谈,否则我不能做任何事。
当我四十岁的时候:我想知道爸爸会怎样处理这件事。他是如此明智。
当我五十岁的时候:如果爸爸在这,我会把所有的东西都给他。太遗憾了,我没有意识到他是多么明智。我本来能从他身上学到更多

 


文章来源:http://stocknewbie.bokee.com/viewdiary.13391801.html
posted @ 2009-05-01 10:52 huohuo 阅读(104) | 评论 (0)编辑 收藏

最近做性能测试,使用jprofile + microsoft web stress tool  测tomcat上的网页.

做了个网页例子,和.net对比速度,发现速度比不过.net

 

用jprofile 跟踪多并发情况,发现在

bean:write 在写整数和日期类型时,会找格式,并且从properties中找不同语言版本的格式.于是会访问

WriteTag.retrieveFormatString

  TagUtils.getInstance().message

       PropertyMessageResource.getMessage(Locale locale, String key)

 

PropertyMessageResource.getMessage(Locale locale, String key) 中有个synchronized 块,这里导致了代码的等待时间过长.

    


文章来源:http://stocknewbie.bokee.com/viewdiary.15201750.html
posted @ 2009-05-01 10:52 huohuo 阅读(144) | 评论 (0)编辑 收藏

<?xml version="1.0" encoding="UTF-8"?>

<project name="cobertura.examples.basic" default="coverage" basedir=".">

 <description>
    Cobertura - http://cobertura.sourceforge.net/
    Copyright (C) 2003 jcoverage ltd.
    Copyright (C) 2005 Mark Doliner &lt;thekingant@users.sourceforge.net&gt;
    Cobertura is licensed under the GNU General Public License
    Cobertura comes with ABSOLUTELY NO WARRANTY
    </description>

 
 <property name="build.dir" value="${basedir}/build"/>
 <!-- 需要测试的代码生成的代码路径-->
 <property name="classes.dir" value="${build.dir}/classes"/>

 <!-- 为需要测试的代码生成的对应的测量类,用于测量覆盖率-->
 <property name="instrumented.dir" value="${build.dir}/instrumented-classes"/>

 
 <!-- 单元测试的代码,这部分代码不生成覆盖率数据,因此和待测试代码要分开-->
 <property name="test.classes.dir" value="${build.dir}/test-classes"/>
 
 <!-- 所有报告的路径-->
 <property name="reports.dir" value="${build.dir}/reports"/>

 <!-- junit 生成两种测试报告的路径,xml和html-->
 <property name="reports.xml.dir" value="${reports.dir}/junit-xml"/>
 <property name="reports.html.dir" value="${reports.dir}/junit-html"/>
 
 <!-- cobertura生成的两种测试覆盖吕的报告,xml和html-->
 <property name="coverage.xml.dir" value="${reports.dir}/cobertura-xml"/>
 <property name="coverage.html.dir" value="${reports.dir}/cobertura-html"/>
 
 
 <property name="src.dir" value="${basedir}/src" />
 <!--测试代码的路径-->
 <property name="test.dir" value="${basedir}/test" />

 
 <path id="cobertura.classpath">
  <fileset dir="${basedir}">
   <include name="lib/unittest/*.jar" />
  </fileset>
 </path>

 <taskdef classpathref="cobertura.classpath" resource="tasks.properties"/>

 <target name="init">
  <mkdir dir="${build.dir}" />
  <mkdir dir="${classes.dir}" />
  <mkdir dir="${test.classes.dir}" />
  <mkdir dir="${instrumented.dir}" />
  <mkdir dir="${reports.xml.dir}" />
  <mkdir dir="${reports.html.dir}" />
  <mkdir dir="${coverage.xml.dir}" />
  <mkdir dir="${coverage.html.dir}" />
 </target>

 <target name="compile" depends="init">
  <javac srcdir="${src.dir}" destdir="${classes.dir}" debug="yes">
   <classpath refid="cobertura.classpath" />
  </javac>
 </target>
 
 
 <target name="compiletest" depends="compile">
  <javac srcdir="${test.dir}" destdir="${test.classes.dir}" debug="yes">
   <classpath location="${classes.dir}"/>
   <classpath refid="cobertura.classpath" />
  </javac>
 </target>

 <target name="instrument" depends="init,compile">
  <!--
   Remove the coverage data file and any old instrumentation.
  -->
  <delete file="cobertura.ser"/>
  <delete dir="${instrumented.dir}" />

  <!--
   Instrument the application classes, writing the
   instrumented classes into ${build.instrumented.dir}.
  -->
  <cobertura-instrument todir="${instrumented.dir}">
   <!--
    The following line causes instrument to ignore any
    source line containing a reference to log4j, for the
    purposes of coverage reporting.
   -->
   <ignore regex="org.apache.log4j.*" />

   <fileset dir="${classes.dir}">
    <!--
     Instrument all the application classes, but
     don't instrument the test classes.
    -->
    <include name="**/*.class" />
    <exclude name="**/*Test.class" />
   </fileset>
  </cobertura-instrument>
 </target>

 <target name="test" depends="init,compiletest">
  <junit fork="yes" dir="${basedir}" haltonerror="no" failureProperty="test.failed">
   <!--
    Note the classpath order: instrumented classes are before the
    original (uninstrumented) classes.  This is important.
   -->
   <classpath location="${instrumented.dir}" />
   <classpath location="${classes.dir}" />
   <classpath location="${test.classes.dir}" />
   <!--
    The instrumented classes reference classes used by the
    Cobertura runtime, so Cobertura and its dependencies
    must be on your classpath.
   -->
   <classpath refid="cobertura.classpath" />

   <formatter type="xml" />
   <test name="${testcase}" todir="${reports.xml.dir}" if="testcase" />
   <batchtest todir="${reports.xml.dir}" unless="testcase">
    <fileset dir="${test.dir}">
     <include name="**/*Test.java" />
    </fileset>
   </batchtest>
  </junit>

  <junitreport >
   <fileset dir="${reports.xml.dir}">
    <include name="TEST-*.xml" />
   </fileset>
   <report format="frames" todir="${reports.html.dir}" />
  </junitreport>
 </target>

 <target name="coverage-check">
  <cobertura-check branchrate="34" totallinerate="100" />
 </target>

 <target name="coverage-report">
  <!--
   Generate an XML file containing the coverage data using
   the "srcdir" attribute.
  -->
  <cobertura-report srcdir="${src.dir}" destdir="${coverage.xml.dir}" format="xml" />
 </target>

 <target name="alternate-coverage-report">
  <!--
   Generate a series of HTML files containing the coverage
   data in a user-readable form using nested source filesets.
  -->
  <cobertura-report destdir="${coverage.html.dir}">
   <fileset dir="${src.dir}">
    <include name="**/*.java"/>
   </fileset>
  </cobertura-report>
 </target>

 <target name="clean" description="Remove all files created by the build/test process.">
  <delete dir="${build.dir}" />
  <delete dir="${classes.dir}" />
  <delete dir="${instrumented.dir}" />
  <delete dir="${reports.dir}" />
  <delete file="cobertura.log" />
  <delete file="cobertura.ser" />
 </target>

 <target name="coverage" depends="clean,compile,instrument,test,coverage-report,alternate-coverage-report" description="Compile, instrument ourself, run the tests and generate JUnit and coverage reports."/>

</project>


文章来源:http://stocknewbie.bokee.com/viewdiary.15201790.html
posted @ 2009-05-01 10:52 huohuo 阅读(663) | 评论 (0)编辑 收藏

select level, d1.dept_id,d1.dept_code,sys_connect_by_path(dept_code,'/') path from zte_fbp_depts d1
start with  d1.dept_id=12
connect by prior d1.dept_id= d1.parent_dept_id


文章来源:http://stocknewbie.bokee.com/viewdiary.16533973.html
posted @ 2009-05-01 10:52 huohuo 阅读(143) | 评论 (0)编辑 收藏

性能测试经验总结
1.要有信心
2.要有稳定,干净的环境,要停掉服务器上不必要的进程和服务

3.要在检查资源是否正常释放了,
内存是否存在泄漏,内存的不断增长,也会影响请求的相应时间
数据库连接是否在使用后得到释放.
可以查看对象的分配状况

要检查查询的时候是将所有的数据查出来了还是只查了一页数据

4.连接池的配置,可以分配足够初始连接,同时配置没有连接时的等待时间,要保证始终是取到连接的
免得测出的是假相.

给出一个配置的例子
 <bean id="dataSource" class="com.zte.platform.db.FolDataSource"
       destroy-method="close">
   <property name="driverClassName" value="oracle.jdbc.driver.OracleDriver"/>
 <property name="url" value=""/>
 <property name="username" value=""/>
 <property name="password" value=""/>
   <property name="initialSize" value="50" />
   <property name="maxActive" value="200" />
   <property name="maxWait" value="-1"/>
   <property name="maxIdle" value="100"/>
   <property name="removeAbandoned" value="true"/>
   <property name="removeAbandonedTimeout" value="30000"/>
   <property name="logAbandoned" value="true"/>
 </bean>

5 要用profile工具,判断在多并发情况下,时间的分配状况,抓住主要矛盾,解决最影响性能的地方

6.服务器需要配置好,对内存和线程都需要配置.
    tomcat配置
    <Connector
port="8088"               maxHttpHeaderSize="8192"
               maxThreads="100" minSpareThreads="100" maxSpareThreads="450"
               enableLookups="false" redirectPort="8443" acceptCount="300"
               connectionTimeout="20000" disableUploadTimeout="true" />

内存配置:
这次测试只配置了java vm,  -Xms1024M -Xmx1024M


有人推荐这样配置:
JVM_ARGS= -Xms1408M -Xmx1408M -XX:MaxPermSize=96M -XX:NewSize=500M -XX:MaxNewSize=500M -Xss128k -XX:+UseConcMarkSweepGC -XX:+UseParNewGC


7.测试脚本中不能带session标识,如http://..../app/perftest.jsp;jsessionid=D68FC8BDDB954F33AD2626D67553EC8E
需要去掉 ;jsessionid=D68FC8BDDB954F33AD2626D67553EC8E ,因为带sessionid会导致测试结果是多个线程访问一个用户的会话.
实际应用中是一个用户一个会话一个线程

8 日志分析,分析日志中出现的异常,异常发生的时候,往往性能会降低,也会引发失败事务.

9. 和其他系统集成了,要先和其他系统分开进行测试,达标一个再集成进来,将问题局部化定位.

10.最好调优人员学会使用 loadrunner测试工具,先自己使用loadrunner测试通过再给测试人员,提高效率

 

 


 


文章来源:http://stocknewbie.bokee.com/viewdiary.17160571.html
posted @ 2009-05-01 10:52 huohuo 阅读(111) | 评论 (0)编辑 收藏

还缺少一个onchange处理,使用正则表达式的处理方式,

以下是限制文字的输入
<style>
 INPUT.num_text
 {
  imme-mode:disabled;
  onkeydown: expression(onkeydown=function ()
  {
   var   k=window.event.keyCode;  
   if(
   k==46||k==8||k==189||k==109||k==190||k==110|| k>=48 && k<=57
   ||k>=96 && k<=105||k>=37 && k<=40 )
   {
    return true;
   }
   else if (k==13)
   {
    window.event.keyCode = 9;
    
    return true;
   }

   else{
    
      return false;
   } 
  });


 }

 

</style>

 

<form>
       <input type="text"   class="num_text"  />

    
</form>


文章来源:http://stocknewbie.bokee.com/viewdiary.18663505.html
posted @ 2009-05-01 10:52 huohuo 阅读(120) | 评论 (0)编辑 收藏

package com.zte.platform;

import java.io.IOException;

import javax.faces.webapp.FacesServlet;
import javax.servlet.ServletConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;

public class ZteFacesServlet extends HttpServlet
{

 private static final String INIT_PARAM_ERROR_PAGE = "errorPage";
        private Log log = LogFactory.getLog(getClass());       
       

 private FacesServlet delegate;

 private String errorPage;

 public void init(ServletConfig servletConfig) throws ServletException
 {
  delegate = new FacesServlet();
  delegate.init(servletConfig);
  errorPage = servletConfig.getInitParameter(INIT_PARAM_ERROR_PAGE);
 }

 public void destroy()
 {
  delegate.destroy();
 }

 public ServletConfig getServletConfig()
 {
  return delegate.getServletConfig();
 }

 public String getServletInfo()
 {
  return delegate.getServletInfo();
 }

 public void service(ServletRequest request, ServletResponse response)
   throws ServletException, IOException
 {
  try
  {
   delegate.service(request, response);
  } catch (Throwable e)
  {
            log.error("page exception ,redirect to error page ",e);
            try{
   redirectToErrorPage((HttpServletRequest) request,
     (HttpServletResponse) response);
            }
            catch(Exception ex)
            {
             log.error("fail to redirect to error page",ex);
             //throw new RuntimeException("fail to redirect to error page,original exceptioin is", e);
            }
  }
 }

 private void redirectToErrorPage(HttpServletRequest request,
   HttpServletResponse response) throws IOException
 {
  if (!"".equals(errorPage))
  {
   response.sendRedirect(request.getContextPath() + errorPage);
  }
 }

}


文章来源:http://stocknewbie.bokee.com/viewdiary.18876476.html
posted @ 2009-05-01 10:52 huohuo 阅读(173) | 评论 (0)编辑 收藏

divHtml = divHtml + "<iframe src='about:blank' style='position:absolute;top:0px;left:0px; visibility:inherit;  width:190px;height:232px;z-index:-1; scrolling='no' frameborder='0' filter='progid:DXImageTransform.Microsoft.Alpha(style=0,opacity=0)';'></iframe>"
  

document.all.myDiv.innerHTML = divHtml;

 

这种方式有个问题,就是width和height写死了,

如果div自身设置了width和height,可以将iframe的width,height设置成100%

divHtml = divHtml + "<iframe src='about:blank' style='position:absolute;top:0px;left:0px; visibility:inherit;  width:100%;height:100%;z-index:-1; scrolling='no' frameborder='0' filter='progid:DXImageTransform.Microsoft.Alpha(style=0,opacity=0)';'></iframe>"


文章来源:http://stocknewbie.bokee.com/viewdiary.18876477.html
posted @ 2009-05-01 10:52 huohuo 阅读(230) | 评论 (0)编辑 收藏

import java.io.BufferedReader;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.FileReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.PushbackInputStream;
import java.util.ArrayList;
import java.util.HashSet;
import java.util.List;
import java.util.Set;

public class UtfTool
{

    /**
     * ant 编译之后的result文件,注意要编译提示错误的文件名要在同一行
     * 可以设置命令提示窗口的缓冲区大小实现
     * @param resultFileName
     */
    public static Set getFileNamesFromCompileResult(String resultFileName)
     throws java.io.IOException
    {
 Set<String> set = new HashSet();
 BufferedReader reader = new BufferedReader(new FileReader(
  resultFileName));
 String start = "[javac] ";
 int startLen = start.length();
 String end = ".java:";
 int endLen = end.length();
 
 String errMsg = "\\65279";
 while (reader.ready())
 {
     String line = reader.readLine();
     int indexStart = line.indexOf(start);
    
     if(line.indexOf(errMsg) == -1)
     {
  continue;
     }
     if (indexStart != -1)
     {
  int indexEnd = line.indexOf(end);
  if (indexEnd != -1)
  {
      String name = line.substring(indexStart + startLen,
       indexEnd + endLen - 1);
      set.add(name.trim());
  }
     }
 }
 return set;

    }
   
    /**
     * 读取流中前面的字符,看是否有bom,如果有bom,将bom头先读掉丢弃
     * @param in
     * @return
     * @throws IOException
     */
    public static InputStream getInputStream(InputStream in) throws IOException
    {

 PushbackInputStream testin = new PushbackInputStream(in);
 int ch = testin.read();
 if (ch != 0xEF)
 {
     testin.unread(ch);
 } else if ((ch = testin.read()) != 0xBB)
 {
     testin.unread(ch);
     testin.unread(0xef);
 } else if ((ch = testin.read()) != 0xBF)
 {
     throw new IOException("错误的UTF-8格式文件");
 } else
 {
     //不需要做,这里是bom头被读完了
    //// System.out.println("still exist bom");

 }
 return testin;

    }
   
   
   
    /**
     * 根据一个文件名,读取完文件,干掉bom头。
     * @param fileName
     * @throws IOException
     */
    public static void trimBom(String fileName) throws IOException
    {

 FileInputStream fin = new FileInputStream(fileName);
 //开始写临时文件
 InputStream in = getInputStream(fin);
 String tmpFileName = fileName + ".tmp";
 FileOutputStream out = new FileOutputStream(tmpFileName);
 byte b[] = new byte[4096];

 int len = 0;
 while (in.available() > 0)
 {
     len = in.read(b, 0, 4096);
     out.write(b, 0, len);
 }

 in.close();
 fin.close();
 out.close();

 //临时文件写完,开始将临时文件写回本文件。
 in = new FileInputStream(tmpFileName);
 System.out.println("[" + fileName + "]");
 out = new FileOutputStream(fileName);

 while (in.available() > 0)
 {
     len = in.read(b, 0, 4096);
     out.write(b, 0, len);
 }
 in.close();
 out.close();
    }

    /**
     * 根据ant编译错误来去除bom
     * @param resultFile
     * @throws IOException
     */
    static void trimBomByCompileResult(String resultFile) throws IOException
    {
 Set<String> set = getFileNamesFromCompileResult(resultFile);
 for (String fName : set)
 {
     trimBom(fName);
 }
    }

    public static void main(String[] args) throws IOException
    {
 trimBomByCompileResult("c:/result3.txt");
 
 ///List<String> list = getFileNamesFromCompileResult(resultFile);

// InputStream in = new FileInputStream(
//  "D:/cc/SSB_SRC_DEV_lijinglin2/TP_SSB/SSB_CJ203_Component/ProductCode/com/zte/ssb/component/access/implementation/dao/ImplementationDAO.java");
// getInputStream2(in);
// in.close();
    }
}


文章来源:http://stocknewbie.bokee.com/viewdiary.22061282.html
posted @ 2009-05-01 10:52 huohuo 阅读(1846) | 评论 (0)编辑 收藏

执行sql

select  o.name,cl.name,cm.text from sysobjects o,syscolumns cl, syscomments cm
 where o.id = cl.id and cl.cdefault = cm.id  and o.type='U'
  and o.name='test2' and cl.name like 'col%'

 

test2是标明, col%是列名通配符, 'U' 表示表格是用户表

 

返回结果:

 

name                           name                           text                                                                                                                                                                                                                                                           
----                           ----                           ----                                                                                                                                                                                                                                                           
test2                          col1                           DEFAULT (0)                                                                                                                                                                                                                                                    
test2                          col2                           DEFAULT  2                                                                                                                                                                                                                                                     
test2                          col3                           DEFAULT  getdate()            

 

 

syscolumns 中 id 表示对应的表格在sysobjects中id, cdefault表示在syscomments中的缺省值注释id

 

 

缺省值可能会出现函数, 例如  default getdate(),

所以我觉得应该这个缺省值可以剥离掉default, 如果使用hibernate实现,还只能用dynamic insert,dynamic update.

 

 


文章来源:http://stocknewbie.bokee.com/viewdiary.31463433.html
posted @ 2009-05-01 10:52 huohuo 阅读(478) | 评论 (0)编辑 收藏