Thursday, March 26, 2009

Oracle String Functions

1.ASCII 
返回与指定的字符对应的十进制数; 
SQL> select ascii(’A’) A,ascii(’a’) a,ascii(’0’) zero,ascii(’ ’) space from dual; 
A A ZERO SPACE 
--------- --------- --------- --------- 
65 97 48 32 

2.CHR 
给出整数,返回对应的字符; 
SQL> select chr(54740) zhao,chr(65) chr65 from dual; 
ZH C 
-- - 
赵 A 
3.CONCAT 
连接两个字符串; 
SQL> select concat(’010-’,’88888888’)||’转23’ 高乾竞电话 from dual; 
高乾竞电话 
---------------- 
010-88888888转23 
4.INITCAP 
返回字符串并将字符串的第一个字母变为大写; 
SQL> select initcap(’smith’) upp from dual; 
UPP 
----- 
Smith 

5.INSTR(C1,C2,I,J) 
在一个字符串中搜索指定的字符,返回发现指定的字符的位置; 
C1 被搜索的字符串 
C2 希望搜索的字符串 
I 搜索的开始位置,默认为1 
J 出现的位置,默认为1 
SQL> select instr(’oracle traning’,’ra’,1,2) instring from dual; 
INSTRING 
--------- 

6.LENGTH 
返回字符串的长度; 
SQL> select name,length(name),addr,length(addr),sal,length(to_char(sal)) from gao.nchar_tst; 
NAME LENGTH(NAME) ADDR LENGTH(ADDR) SAL LENGTH(TO_CHAR(SAL)) 
------ ------------ ---------------- ------------ --------- -------------------- 
高乾竞 3 北京市海锭区 6 9999.99 7 

7.LOWER 
返回字符串,并将所有的字符小写 
SQL> select lower(’AaBbCcDd’)AaBbCcDd from dual; 
AABBCCDD 
-------- 
aabbccdd 

8.UPPER 
返回字符串,并将所有的字符大写 
SQL> select upper(’AaBbCcDd’) upper from dual; 
UPPER 
-------- 
AABBCCDD 

9.RPAD和LPAD(粘贴字符) 
RPAD 在列的右边粘贴字符 
LPAD 在列的左边粘贴字符 
SQL> select lpad(rpad(’gao’,10,’*’),17,’*’)from dual; 
LPAD(RPAD(’GAO’,1 
----------------- 
*******gao******* 
不够字符则用*来填满 

10.LTRIM和RTRIM 
LTRIM 删除左边出现的字符串 
RTRIM 删除右边出现的字符串 
SQL> select ltrim(rtrim(’ gao qian jing ’,’ ’),’ ’) from dual; 
LTRIM(RTRIM(’ 
------------- 
gao qian jing 

11.SUBSTR(string,start,count) 
取子字符串,从start开始,取count个 
SQL> select substr(’13088888888’,3,8) from dual; 
SUBSTR(’ 
-------- 
08888888 

12.REPLACE(’string’,’s1’,’s2’) 
string 希望被替换的字符或变量 
s1 被替换的字符串 
s2 要替换的字符串 
SQL> select replace(’he love you’,’he’,’i’) from dual; 
REPLACE(’H 
---------- 
i love you 

13.SOUNDEX 
返回一个与给定的字符串读音相同的字符串 
SQL> create table table1(xm varchar(8)); 
SQL> insert into table1 values(’weather’); 
SQL> insert into table1 values(’wether’); 
SQL> insert into table1 values(’gao’); 
SQL> select xm from table1 where soundex(xm)=soundex(’weather’); 
XM 
-------- 
weather 
wether 

14.TRIM(’s’ from ’string’) 
LEADING 剪掉前面的字符 
TRAILING 剪掉后面的字符 
如果不指定,默认为空格符

How to open *.bin file in Linux

Ensure you trust the source of the file. The following procedure will allow the bin file to make any changes it wants to make to your system.

- Save the bin file to your home folder.
- Click Applications, Accessories, Terminal.
- Press ENTER after each command below.
- To make the BIN file executable: In the terminal, type the command:
chmod 755 NameOfBinFile.bin
- To run the file and install RealPlayer type the command:
sudo ./NameOfBinFile.bin
- Follow the on screen prompts.Press space to page down if any.

Wednesday, March 25, 2009

Python、Lua和Ruby [转]

译者按:Python、lua和ruby在C/C++是日渐式微的情况下,在java/.net的围歼中努力抗争的三个当红小生。在Tom Gutschmidt的著作《Game Programmng with Python, Lua and Ruby》一书中,介绍了三种语言在游戏中的应用,其中尤为了不起的是在书中最后一章中比较了三种脚本,作者没有说孰优孰劣,但是读者你认为呢?欢迎留言讨论。
 
So which of the three languages is the best to use on your project? That depends a great deal on what you want to accomplish. To wrap up the book, I've outlined some of the pros and cons of each language in this section.
这三种语言中的哪一种更合适你的项目?很大程度取决于你想达到什么样的目标。作为一书的结尾,在这一节里,我会描述一下它们各自的优点和不足。
Python Pros and Cons
Python的优点和不足
The pros of Python are as follows:
Python的优点如下:
·         Python has more extension modules than the other languages.
·         Python比其它语言有更多扩展模块。
·         Many online Python tutorials exist. There are also plenty of English books and reference materials, many sample scripts exist online, and there is a wealth of introductory material. The Python.org Website is a good place to start looking for these because it has sections for beginners, tutorials, guides organized by topic, and lists of links and references.
·         在网上可以找到很多Python教程。不仅如此,还有大量的英文书籍和资料。Python.org有很多为初学者准备的依主题组织的资料、教程和编程指南,此外还有很多链接和参考。
·         Most folks really enjoy the syntax of the Python language because it appears clean and is easy to read.
·         很多人都喜欢Python语言的语法,因为它清晰易读。
·         Python has an edge where libraries are concerned. There are many libraries, and, for the most part, they are well documented.
·         Python在支持库上大占优势,因为它有很多库,而且大部分都有完善的文档支持。
·         Lots of tools that tie into Python are available, and they are often easier to find than the tools for Lua and Ruby.
·         很多工具可以用于Python,但难以找到适用于Lua和Ruby的。
The cons of Python are as follows:
Python的不足:
·         Existing Python debuggers are considered quirky and slow. Debugging support on Macintosh and consoles is even weaker.
·         现有的Python调试器诡异而且效率低下。在Macintosh(苹果计算机)和控制台下进行调试是一个梦魇。
·         It can be difficult to bundle Python with other languages. There are lots of binary DLLs, and Python has (compared to the other languages) a large standard distribution.
·         Python难以与其它语言集成,它有太多的二进制DLL,而且Python带了巨大的标准发布包。
·         Lots of folks really dislike the white space sensitivity of Python syntax.
·         同样的,也有很多人不喜欢Python对空白符敏感的语法。
·         Python can be quite slow at times, as everything is an object on the heap.
·         因为栈上的任何东西都是对象,所以Python有时候会慢得难以忍受。
Lua Pros and Cons
Lua的优点和不足
The pros of Lua are as follows:
Lua的优点:
·         Lua is probably the fastest of the three languages and usually uses the least amount of runtime memory.
·         Lua在这三种语言中是运行时速度最快而且占内在最少的。
·         Lau has the smallest memory footprint for bundling.
·         集成Lua只会增加极少的内存占用率。
·         The Lau C API is very well documented and has good examples for integrating with C.
·         Lua的C API有着完备着文档和很好的例子,可以容易地通过C集成在软件里。
The cons of Lua are as follows:
Lua的不足:
·         The documentation has improved but is still a bit sketchy overall. Of the three languages, Lua it is probably the least documented (the API being the exception), with the least amount of code comments. This makes for the largest ramp-up time to learn, and there isn't much in the way of introductory Lua material.
·         尽管Lua的文档已经增进不少,但仍然有所不足。三种语言中,Lua可能是文档最少的(API方面是个例外),因为代码中极少注释,这也增加了学习的难度。另外,对Lua的本质也没有什么介绍。
·         There isn't a lot of built-in functionality for Lua. There is little support if you need to create a large, complex application.
·         Lua内建的功能很少,并没有对创建大型的复杂应用程序提供足够支持。
·         Lua could use a better garbage collectorthe current development is moving towards that now. Right now, Lua GC uses a very simple and traditional simple mark and sweep.
·         Lua应该使用更好的垃圾收集机制,Lua现在的GC仍然使用非常简单而且传统的“标记和清除”方式。
Pros and Cons of Ruby
Ruby的优点和不足
The pros of Ruby are as follows:
Ruby的优点:
·         Ruby possesses fairly good advanced debuggers.
·         Ruby有极好的高级调试器。
·         Ruby is object oriented from the ground up, and programmers who are OOP enthusiasts or who are used to the OOP paradigm will find the language extremely comfortable.
·         Ruby是最彻底的面向对象语言,对于OOP狂热者和惯于使用OOP范式的程序员,他们将会发现Ruby是最适合他们的语言。
·         Ruby has arguably the simplest syntax, with no real rules exceptions. Especially true for OOP enthusiasts. 
·         Ruby的语法极为简单,没有让人出乎意料规则,特别适合OOP行家的习惯。
The cons of Ruby are as follows:
Ruby的不足:
·         Lack of English documentation.
·         英文文档极度缺乏。
·         Fewer existing works and samples for games than with the other languages.
·         与其它语言相比,在游戏方面所作的工作和实例都少得多。

Tuesday, March 24, 2009

查询数据库版本信息

查询Oracle数据库版本信息
select * from v$instance
select * from product_component_version

查询SqlServer版本信息
select @@version version

Monday, March 23, 2009

JDK中Jconsole的使用[REF]

JAVA应用程序打成jar包的部署方式: 

一、Local方式 
1、cmd进入dos下,进入到应用程序所在目录,执行语句如下: 
java -Dcom.sun.management.jmxremote -jar 程序名.jar 
(java -Dcom.sun.management.jmxremote -jar Java2Demo.jar)(测试例子Java2Demo.jar在C:\Program Files\Java\jdk1.6.0_02\demo\jfc\Java2D\) 

还出不来的话 直接 在dos里 jconsole 进程号 

2、启动jdk_home\bin目录下的Jconsole.exe就可以看到有一个 

本地的连接在里面。点击连接就可以进入相应的监视界面了。 

二、JMX方式(远程连接): 
1、cmd进入dos下,进入到应用程序所在目录,执行语句如下: 
java -Dcom.sun.management.jmxremote.port=8903 - 

Dcom.sun.management.jmxremote.ssl=false - 

Dcom.sun.management.jmxremote.authenticate=false 
-Djava.rmi.server.hostname=192.168.***.*** 

2、启动jdk_home\bin目录下的Jconsole.exe点高级。在JMX 

URL:中输入语句如下: 

service:jmx:rmi:///jndi/rmi://192.168.***.***:8903/jmxr 

mi 
点连接就可以进行远程监控了 



web应用程序在tomcat中部署JMX(示例:tomcat-6.0.14) 
1、启动tomcat\bin目录下的tomcat6w.exe,在JAVA_OPTS里设 

置如下: 
-Dcom.sun.management.jmxremote.port=8903 
-Dcom.sun.management.jmxremote.ssl=false 
-Dcom.sun.management.jmxremote.authenticate=false 
-Djava.rmi.server.hostname=192.168.***.*** 

注意:不能有空格,不然tomcat不能启动。 

2、tomcat启动成功后,就可以在另一台机器上启动 

jdk_home\bin目录下的Jconsole.exe点高级。在JMX URL:中输 

入语句如下: 

service:jmx:rmi:///jndi/rmi://192.168.***.***:8903/jmxr 

mi 
点连接就可以进行远程监控了 

以上是JMX基本部署,没有涉及到验证方面,如果使用的话,可 

能会有漏洞,因为SSL和authenticate设置为false的话,那么 

8903端口就有可能有暴露的危险。 

如果想进行密码验证话,可以在网上找资料,自己进行调试。 


我自己的应用: 
1.修改Linux下tomcat的bin目录下的catalina.sh文件 
添加 
JAVA_OPTS=-Dcom.sun.management.jmxremote.authenticate=false -Dcom.sun.management.jmxremote.ssl=false 
-Dcom.sun.management.jmxremote.port=7080  
-Dcom.sun.management.jmxremote 
2.修改/etc/hosts文件下的localhost对应的IP(127.0.0.1)地址,改为linux自身的IP如10.0.0.157. 
3.打开jconsole远程输入 10.0.0.157:7080 

三 

Eden Space (heap): 内存最初从这个线程池分配给大部分对象。 
Survivor Space (heap):用于保存在eden space内存池中经过垃圾回收后没有被回收的对象。 
Tenured Generation (heap):用于保持已经在 survivor space内存池中存在了一段时间的对象。 
Permanent Generation (non-heap): 保存虚拟机自己的静态(refective)数据,例如类(class)和方法(method)对象。Java虚拟机共享这些类数据。这个区域被分割为只读的和只写的, 
Code Cache (non-heap):HotSpot Java虚拟机包括一个用于编译和保存本地代码(native code)的内存,叫做“代码缓存区”(code cache)

Thursday, March 19, 2009

实体化试图(Materialized View)介绍

实体化视图or物化视图概述 

A materialized view provides indirect access to table data by storing the results of a query in a separate schema object. Unlike an ordinary view, which does not take up any storage space or contain any data.

Oracle的实体化视图提供了强大的功能,可以用在不同的环境中。在不同的环境中,实体化视图的作用也不相同。数据仓库中的实体化视图主要用于预先计算并保存表连接或聚集等耗时较多的操作的结果,这样,在执行查询时,就可以避免进行这些耗时的操作,而从快速的得到结果。在数据仓库中,还经常使用查询重写(query rewrite)机制,这样不需要修改原有的查询语句,Oracle会自动选择合适的实体化视图进行查询,完全对应用透明。实体化视图和表一样可以直接进行查询。实体化视图可以基于分区表,实体化视图本身也可以分区。除了在数据仓库中使用,实体化视图还用于复制、移动计算等方面。实体化视图有很多方面和索引很相似:使用实体化视图的目的是为了提高查询性能;实体化视图对应用透明,增加和删除实体化视图不会影响应用程序中SQL语句的正确性和有效性;实体化视图需要占用存储空间;当基表发生变化时,实体化视图也应当刷新。

物化视图是包括一个查询结果的数据库对像,它是远程数据的的本地副本,或者用来生成基于数据表求和的汇总表。物化视图存储基于远程表的数据,也可以称为快照。

物化视图可以查询表,视图和其它的物化视图。

通常情况下,物化视图被称为主表(在复制期间)或明细表(在数据仓库中)。

对于复制,物化视图允许你在本地维护远程数据的副本,这些副本是只读的。如果你想修改本地副本,必须用高级复制的功能。当你想从一个表或视图中抽取数据时,你可以用从物化视图中抽取。

需要注意的地方,物化视图是数据仓库的技术,如果想要做到时时的数据更新,必然会对oltp类型的数据库造成影响,那么在作物化视图的时候需要衡量,权衡是否需要这样的视图,如果需要,那么就有不要牺牲时时更新数据,可以在oltp系统不繁忙的时候来让系统自动刷新统计值。而且在建立的时候,最好不要在业务繁忙的时候建立。

Monday, March 16, 2009

在ORACLE中创建自增字段

通过创建序列来实现 
ORACLE SEQUENCE的简单介绍 


在oracle中sequence就是所谓的序列号,每次取的时候它会自动增加,一般用在需要按序列号排序的地方。 
1、Create Sequence 
你首先要有CREATE SEQUENCE或者CREATE ANY SEQUENCE权限, 
CREATE SEQUENCE emp_sequence 
INCREMENT BY 1 -- 每次加几个 
START WITH 1 -- 从1开始计数 
NOMAXVALUE -- 不设置最大值 
NOCYCLE -- 一直累加,不循环 
CACHE 10; 

一旦定义了emp_sequence,你就可以用CURRVAL,NEXTVAL 
CURRVAL=返回 sequence的当前值 
NEXTVAL=增加sequence的值,然后返回 sequence 值 
比如: 
emp_sequence.CURRVAL 
emp_sequence.NEXTVAL 

可以使用sequence的地方: 
- 不包含子查询、snapshot、VIEW的 SELECT 语句 
- INSERT语句的子查询中 
- NSERT语句的VALUES中 
- UPDATE 的 SET中 

可以看如下例子: 
INSERT INTO emp VALUES 
(empseq.nextval, 'LEWIS', 'CLERK',7902, SYSDATE, 1200, NULL, 20); 

SELECT empseq.currval FROM DUAL; 

但是要注意的是: 
- 第一次NEXTVAL返回的是初始值;随后的NEXTVAL会自动增加你定义的INCREMENT BY值,然后返回增加后的值。CURRVAL 总是返回当前SEQUENCE的值,但是在第一次NEXTVAL初始化之后才能使用CURRVAL,否则会出错。一次NEXTVAL会增加一次SEQUENCE的值,所以如果你在同一个语句里面使用多个NEXTVAL,其值就是不一样的。明白? 

- 如果指定CACHE值,ORACLE就可以预先在内存里面放置一些sequence,这样存取的快些。cache里面的取完后,oracle自动再取一组到cache。 使用cache或许会跳号, 比如数据库突然不正常down掉(shutdown abort),cache中的sequence就会丢失. 所以可以在create sequence的时候用nocache防止这种情况。 

2、Alter Sequence 
你或者是该sequence的owner,或者有ALTER ANY SEQUENCE 权限才能改动sequence. 可以alter除start至以外的所有sequence参数.如果想要改变start值,必须 drop sequence 再 re-create . 
Alter sequence 的例子 
ALTER SEQUENCE emp_sequence 
INCREMENT BY 10 
MAXVALUE 10000 
CYCLE -- 到10000后从头开始 
NOCACHE ; 


影响Sequence的初始化参数: 
SEQUENCE_CACHE_ENTRIES =设置能同时被cache的sequence数目。 

可以很简单的Drop Sequence 
DROP SEQUENCE order_seq;

Monday, March 9, 2009

linux下如何运行shell脚本

和   window   的bat编写方法基本一样,无非是把命令用linux中的shell中的命令代理就可以了,   
  最重要的是,文件保存以后要把属性设置正确一定要   +x     这样才可以执行。
可以使用WinScp来设置或者linux命令   
    
这样就行了。 

运行时使用sh **.sh即可执行,或者./*.sh 来运行

Thursday, March 5, 2009

database tip

数据库连接对象调用close方法后,还把连接对象置为null;

个人决论:数据库连接对象调用close()方法关闭后,并没有马上关闭,但同时把连接对象置为null,有助于gc来回收连接对象从而加快数据库连接对象的回收吧。

Java Class

对象的创建有四种方式: 
1、用new语句创建对象 
2、用反射机制 java.lang.Class或者java.lang.reflect.Constructor类newInstance()方法 
3、调用clone()方法 
4、运用序列化方式,java.io.ObjectInputStream对象的readObject()方法

Sunday, March 1, 2009

【转】log4j xml配置详解

熟读一个典型的log4j配置文件:

一、概述

 Log4j是Apache的一个开放源代码项目,通过使用Log4j,我们可以控制日志信息输送的目的地是控制台、文件、GUI组件、甚至是套接口服务器、NT的事件记录器、UNIX Syslog守护进程等;我们也可以控制每一条日志的输出格式;通过定义每一条日志信息的级别,我们能够更加细致地控制日志的生成过程。最令人感兴趣的就是,这些可以通过一个配置文件来灵活地进行配置,而不需要修改应用的代码。
  
  此外,通过Log4j其他语言接口,您可以在C、C++、.Net、PL/SQL程序中使用Log4j,其语法和用法与在Java程序中一样,使得多语言分布式系统得到一个统一一致的日志组件模块。而且,通过使用各种第三方扩展,您可以很方便地将Log4j集成到J2EE、JINI甚至是SNMP应用中。

二,使用前的准备。
 1、下载log4j 地址为:http://jakarta.apache.org/log4j/docs/download.html.
 2、你可能要用到的jar文件有:  如果需要将日志发送到邮箱,则需要javamail API,JAF API (the JavaBeans Activation Framework)
下载地址:  http://java.sun.com/products/javamail/
 http://java.sun.com/beans/glasgow/jaf.html
  如果需要jms的支持,则需要jms API 下载地址为:http://java.sun.com/products/jms/vendors.html
三, Log4j介绍
 Log4j由三个重要的组件构成:日志信息的优先级 priority,日志信息的输出目的地Appender,日志信息的输出格式(布局)layout。
日志的优先级,
 从低到高,依次有:DEBUG,INFO,WARN,ERROR,分别用来指定这条日志信息的重要程度;如果定义了了输入的级别为INFO,则只有等于及高于这个级别的才进行处理,此时将输入INFO,WARN,ERROR。值得注意的是,级别中还有两个关键字,
 ALL:打印所有的日志,
 OFF:关闭所有的日志输出。

1、 Loggers  

Loggers组件在此系统中被分为五个级别:DEBUG、INFO、WARN、ERROR和FATAL。这五个级别是有顺序的,
DEBUG 小于 INFO 小于 WARN 小于 ERROR 小于 FATAL,分别用来指定这条日志信息的重要程度,明白这一点很重要,
这里Log4j有一个规则:假设Loggers级别为P,如果在Loggers中发生了一个级别Q比P高,则可以启动,否则屏蔽掉。
假设你定义的级别是info,那么error和warn的日志可以显示而比他低的debug信息就不显示了。
  
  Java程序举例来说:
  
  //建立Logger的一个实例,命名为“com.foo”
  Logger logger = Logger.getLogger("com.foo"); //"com.foo"是实例进行命名,也可以任意

  //设置logger的级别。通常不在程序中设置logger的级别。一般在配置文件中设置。
  logger.setLevel(Level.INFO);
  Logger barlogger = Logger.getLogger("com.foo.Bar");

  //下面这个请求可用,因为WARN 大于等于 INFO
  logger.warn("Low fuel level.");

  //下面这个请求不可用,因为DEBUG 小于 INFO
  logger.debug("Starting search for nearest gas station.");

  //命名为“com.foo.bar”的实例barlogger会继承实例“com.foo”的级别。
    //因此,下面这个请求可用,因为INFO 大于等于 INFO
  barlogger.info("Located nearest gas station.");

  //下面这个请求不可用,因为DEBUG 小于 INFO
  barlogger.debug("Exiting gas station search");

  这里“是否可用”的意思是能否输出Logger信息。
  在对Logger实例进行命名时,没有限制,可以取任意自己感兴趣的名字。
    一般情况下建议以类的所在位置来命名Logger实例,这是目前来讲比较有效的Logger命名方式。
    这样可以使得每个类建立自己的日志信息,便于管理。比如:  
  static Logger logger = Logger.getLogger(ClientWithLog4j.class.getName());
 2、输出端 Appender  log4j提供了以下几种常用的输出目的地:
 org.apache.log4j.ConsoleAppender,将日志信息输出到控制台
 org.apache.log4j.FileAppender,将日志信息输出到一个文件

 org.apache.log4j.DailyRollingFileAppender,将日志信息输出到一个,并且每天输出到一个新的日志文件,按照不同的配置可以定义每月一个日志文件,或者每周,每天,每小时,每分钟等输出一个新的日志文件。
 org.apache.log4j.RollingFileAppender,将日志信息输出到一个文件,通过指定文件的的尺寸,当文件大小到达指定尺寸的时候会自动把文件改名,如名为example.log的文件会改名为example.log.1,同时产生一个新的example.log文件。如果新的文件再次达到指定尺寸,又会自动把文件改名为example.log.2,同时产生一个example.log文件。依此类推,直到example.log. MaxBackupIndex,MaxBackupIndex的值可在配置文件中定义。
 org.apache.log4j.WriterAppender,将日志信息以流格式发送到任意指定的地方。
 org.apache.log4j.jdbc.JDBCAppender,通过JDBC把日志信息输出到数据库中。
 org.apache.log4j.net.SMTPAppender,将日志信息以邮件的方式发送到指定的邮箱。

 3、输出格式(布局)layout
 通过appender可以控制输出的目的地,而如果要控制输出的格式,就可通过log4j的layout组件来实现。通过配置文件定义一个appender的输出格式,Log4j提供的布局模式有以下几种:
 org.apache.log4j.ConsoleAppender,输出到控制台
 org.apache.log4j.HTMLLayout,以HTML表格形式布局
 org.apache.log4j.PatternLayout,可以灵活地指定布局模式
 org.apache.log4j.SimpleLayout,包含日志信息的级别和信息字符串

1.HTMLLayout 选项

LocationInfo=true:默认值是false,输出java文件名称和行号

    Title=my app file: 默认值是 Log4J Log Messages.

2.PatternLayout 选项

  ConversionPattern=%m%n :指定怎样格式化指定的消息。

3.XMLLayout  选项

  LocationInfo=true:默认值是false,输出java文件和行号

实际应用:

  log4j.appender.A1.layout=org.apache.log4j.PatternLayout 

 值得一提的是org.apache.log4j.PatternLayout 以Pattern方式的布局,使用Pattern的方式来指定布局。

pattern 的参数如下:ConversionPattern参数的格式含义
 格式名 含义
 %c 输出日志信息所属的类的全名
 %d 输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,比如:%d{yyy-MM-dd HH:mm:ss },输出类似:2002-10-18- 22:10:28 ;比如 %d{HH:mm:ss,SSS} 或 %d{dd MMM yyyy HH:mm:ss,SSS}.
格式可以参考 java类 SimpleDateFormat,不过 按照此类的设置会影响速度。你可以选择更快的方式 %d{ISO8601},%d{ABSOLUTE}, %d{RELATIVE}.或者使用log4j的ISO8601DateFormat, AbsoluteTimeDateFormat,RelativeTimeDateFormat 和 DateTimeDateFormat 方式.
 %f 输出日志信息所属的类的类名
 %l 输出日志事件的发生位置,即输出日志信息的语句处于它所在的类的第几行
 %m 输出代码中指定的信息,如log(message)中的message
 %M 输出日志信息中所发生的方法名。
 %n 输出一个回车换行符,Windows平台为“\r\n”,Unix平台为“\n”
 %p 输出优先级,即DEBUG,INFO,WARN,ERROR,FATAL。如果是调用debug()输出的,则为DEBUG,依此类推
 %r 输出自应用启动到输出该日志信息所耗费的毫秒数
 %t 输出产生该日志事件的线程名

-------------------------------------------------------------------

(1). 输出方式appender一般有5种:

             org.apache.log4j.RollingFileAppender(滚动文件,自动记录最新日志)
             org.apache.
log4j.ConsoleAppender (控制台)  
             org.apache.
log4j.FileAppender (文件)
             org.apache.
log4j.DailyRollingFileAppender (每天产生一个日志文件)
             org.apache.
log4j.WriterAppender (将日志信息以流格式发送到任意指定的地方) 

(2). 日记记录的优先级priority,优先级由高到低分为
            OFF ,FATAL ,ERROR ,WARN ,INFO ,DEBUG ,ALL。
           
Log4j建议只使用FATAL ,ERROR ,WARN ,INFO ,DEBUG这五个级别。 

(3). 格式说明layout中的参数都以%开始,后面不同的参数代表不同的格式化信息(参数按字母表顺序列出):
                %c        输出所属类的全名,可在修改为 %d{Num} ,Num类名输出的维(如:"org.apache.elathen.ClassName",%C{2}将输出elathen.ClassName)
                %d       输出日志时间其格式为 %d{yyyy-MM-dd HH:mm:ss,SSS},可指定格式 如 %d{HH:mm:ss}
                %l        输出日志事件发生位置,包括类目名、发生线程,在代码中的行数
                %n       换行符
                %m      输出代码指定信息,如info(“message”),输出message
                %p       输出优先级,即 FATAL ,ERROR 等
                %r        输出从启动到显示该log信息所耗费的毫秒数
                %t        输出产生该日志事件的线程名

参考资料
 1.http://www.vipan.com/htdocs/log4jhelp.html
         Don't Use System.out.println! Use Log4j - Vipan Singla
 2.http://jakarta.apache.org/log4j/docs/manual.html
  Short introduction to log4j - Ceki Gülcü - March 2002
 3.http://www-128.ibm.com/developerworks/cn/java/jw-log4j/
 log4j提供了对日志记录的控制
 4.http://logging.apache.org/log4j/docs/documentation.html
 log4j提供的文档。

5. http://wc-stone.javaeye.com/blog/134854

6. http://www.blogjava.net/hua/archive/2006/08/29/66420.html

7. http://zhangxiang390.javaeye.com/blog/258455

-----------------------------------------------------

 Log4j比较全面的配置 <<<<

 LOG4J的配置之简单使它遍及于越来越多的应用中了:Log4J配置文件实现了输出到控制台、文件、回滚文件、发送日志邮件、输出到数据库日志表、自定义标签等全套功能。择其一二使用就够用了,

 log4j.rootLogger=DEBUG,CONSOLE,A1,im
 log4j.addivity.org.apache=true

 # 应用于控制台

 log4j.appender.CONSOLE=org.apache.log4j.ConsoleAppender
 log4j.appender.Threshold=DEBUG
 log4j.appender.CONSOLE.Target=System.out
 log4j.appender.CONSOLE.layout=org.apache.log4j.PatternLayout
 log4j.appender.CONSOLE.layout.ConversionPattern=[framework] %d - %c -%-4r [%t] %-5p %c %x - %m%n
 #log4j.appender.CONSOLE.layout.ConversionPattern=[start]%d{DATE}[DATE]%n%p[PRIORITY]%n%x[NDC]%n%t[THREAD] n%c[CATEGORY]%n%m[MESSAGE]%n%n

 #应用于文件

 log4j.appender.FILE=org.apache.log4j.FileAppender
 log4j.appender.FILE.File=file.log
 log4j.appender.FILE.Append=false
 log4j.appender.FILE.layout=org.apache.log4j.PatternLayout
 log4j.appender.FILE.layout.ConversionPattern=[framework] %d - %c -%-4r [%t] %-5p %c %x - %m%n
 # Use this layout for LogFactor 5 analysis

 # 应用于文件回滚

 log4j.appender.ROLLING_FILE=org.apache.log4j.RollingFileAppender
 log4j.appender.ROLLING_FILE.Threshold=ERROR
 log4j.appender.ROLLING_FILE.File=rolling.log  //文件位置,也可以用变量${java.home}、rolling.log
 log4j.appender.ROLLING_FILE.Append=true       //true:添加  false:覆盖
 log4j.appender.ROLLING_FILE.MaxFileSize=10KB   //文件最大尺寸
 log4j.appender.ROLLING_FILE.MaxBackupIndex=1  //备份数
 log4j.appender.ROLLING_FILE.layout=org.apache.log4j.PatternLayout
 log4j.appender.ROLLING_FILE.layout.ConversionPattern=[framework] %d - %c -%-4r [%t] %-5p %c %x - %m%n


 #应用于socket
 log4j.appender.SOCKET=org.apache.log4j.RollingFileAppender
 log4j.appender.SOCKET.RemoteHost=localhost
 log4j.appender.SOCKET.Port=5001
 log4j.appender.SOCKET.LocationInfo=true
 # Set up for Log Facter 5
 log4j.appender.SOCKET.layout=org.apache.log4j.PatternLayout
 log4j.appender.SOCET.layout.ConversionPattern=[start]%d{DATE}[DATE]%n%p[PRIORITY]%n%x[NDC]%n%t[THREAD]%n%c[CATEGORY]%n%m[MESSAGE]%n%n


 # Log Factor 5 Appender
 log4j.appender.LF5_APPENDER=org.apache.log4j.lf5.LF5Appender
 log4j.appender.LF5_APPENDER.MaxNumberOfRecords=2000

 # 发送日志给邮件

 log4j.appender.MAIL=org.apache.log4j.net.SMTPAppender
 log4j.appender.MAIL.Threshold=FATAL
 log4j.appender.MAIL.BufferSize=10
 
log4j.appender.MAIL.From=web@www.wuset.com
 log4j.appender.MAIL.SMTPHost=www.wusetu.com
 log4j.appender.MAIL.Subject=Log4J Message
 
log4j.appender.MAIL.To=web@www.wusetu.com
 log4j.appender.MAIL.layout=org.apache.log4j.PatternLayout
 log4j.appender.MAIL.layout.ConversionPattern=[framework] %d - %c -%-4r [%t] %-5p %c %x - %m%n

 # 用于数据库
 log4j.appender.DATABASE=org.apache.log4j.jdbc.JDBCAppender
 log4j.appender.DATABASE.URL=jdbc:mysql://localhost:3306/test
 log4j.appender.DATABASE.driver=com.mysql.jdbc.Driver
 log4j.appender.DATABASE.user=root
 log4j.appender.DATABASE.password=
 log4j.appender.DATABASE.sql=INSERT INTO LOG4J (Message) VALUES ('[framework] %d - %c -%-4r [%t] %-5p %c %x - %m%n')
 log4j.appender.DATABASE.layout=org.apache.log4j.PatternLayout
 log4j.appender.DATABASE.layout.ConversionPattern=[framework] %d - %c -%-4r [%t] %-5p %c %x - %m%n


 log4j.appender.A1=org.apache.log4j.DailyRollingFileAppender
 log4j.appender.A1.File=SampleMessages.log4j
 log4j.appender.A1.DatePattern=yyyyMMdd-HH'.log4j'
 log4j.appender.A1.layout=org.apache.log4j.xml.XMLLayout

 #自定义Appender

 log4j.appender.im = net.cybercorlin.util.logger.appender.IMAppender

 log4j.appender.im.host = mail.cybercorlin.net
 log4j.appender.im.username = username
 log4j.appender.im.password = password
 log4j.appender.im.recipient =
corlin@cybercorlin.net

 log4j.appender.im.layout=org.apache.log4j.PatternLayout
 log4j.appender.im.layout.ConversionPattern =[framework] %d - %c -%-4r [%t] %-5p %c %x - %m%n