java开发的很多代码都是可以通过工具来生成的,虽然eclipse在这方面有些帮助,但其能力还是太有限,在本人学习ruby期间发现使用ruby来写个自动化的生成工具确实是个很不错的主意。由于公司使用的oracle+ibatis的持久层开发,所以本人开始的时间只是想生成一下ibatis的sqlmap的XML文件就可以了,但后来一想,其实service、dao、controller甚至JSP都可以完成大部分的有效生成。但即便如此,这个工具的代码量还是很小的,几乎是相当的容易。
由于本人主要是做JAVA的,所以ruby这个东西过段时间就忘了,可能再到以后再要想搞这么个工具,又得从头再来,所以决定把大体思路写下来。
其中涉及到的东西主要有几下几个:
1.读取配置文件。由于windows下的tcl/tk非常的难用(是本人目前用过的最难用的API之一),所以觉得还是用配置文件算了。XML不错,但结构有点复杂,所以本人使用的是yaml格式配置文件,感觉其与json有点相似。大体格式如下:

#tnsnames.ora, yaml要求冒号后面要有空格,仅用于测试数据库
tns : ORCL181
table : PAY_WAY_COL
domain_pack: com



由于yaml是ruby标准库自带的,所以不需要再安装gem,只要在使用时用require引入即可。


2.连接数据库组件。连接oracle时,除了需要dbi以外,还需要oci8这个gem,因此这个得自己手动安装。


3.将ruby程序打包成exe文件,这个需要个叫exerb的组件,其用法可见下面文章:


[url]http://jimmykuu.iteye.com/blog/51526[/url]


4.生成java需要的技术。生成xml文件是可以使用rexml,这个在本人以前的博客中也讲过,生成java文件时,除了可以使用普通的puts "xxxx"输出到文件以外,还可以使用erb模版技术,本人也两种都试了下,感觉erb模版方法可能更好一些。



除了上面这些问题外,就剩下写代码了,下面贴出生成文件的主要结构代码:


=begin
dao service controller domain sqlmap ...
=end
$LOAD_PATH.unshift(File.dirname(__FILE__)) unless $LOAD_PATH.include?(File.dirname(__FILE__))

require 'dbi'
require 'oci8'
require "yaml"

require "sqlmap"
require "domain"
require "dao_service"
require "xml_service"
require "controller"
require "bean_util"
require "list"
require "form_jsp"

class CrudModel

	def initialize(tns,table,dpack,crud_pack,author)
		@tns = tns
		@table=table
		@clazz=BeanUtils.class_name(table)
		@name=BeanUtils.bean_name(table)
		#domain package
		@dpack=dpack
		#service dao controller package
		@crud_pack=crud_pack
		@author=author

		DBI.connect("DBI:OCI8:#{@tns}","qaa","qaajkwin") do |dbh|
			#查询表的主键
			rs_id = dbh.execute("select ucc.column_name as ID from user_cons_columns ucc, user_constraints uc
					where ucc.constraint_name = uc.constraint_name
					and uc.constraint_type = 'P' and uc.table_name = upper('#{@table}')")

			@primary_key = rs_id.fetch_hash["ID"]
			@id=BeanUtils.field_to_attr(@primary_key)

			#获取表的基本信息
			rs = dbh.execute("select * from "+@table)
			rs_seq = dbh.execute("select count(*) as seqcount from all_sequences 
				where sequence_name='#{@table}_SEQUENCE'")

			sqlmap = SqlMapXml.new(rs_seq,rs,@table,@clazz,@name,@dpack,@primary_key,@id)
			sqlmap.write()

			domain = Domain.new(rs,@table,@clazz,@dpack)
			domain.write()

			dao_service = DaoService.new(@clazz,@name,@dpack,@crud_pack,@author)
			dao_service.write()

			xml_service = XmlService.new(@clazz,@name,@crud_pack)
			xml_service.write()

			controller = Controller.new(@clazz,@name,@id,@dpack,@crud_pack,@author)
			controller.write()

			#获取表的列注释
			rs_comments = dbh.execute("select column_name as columnName,comments 
				from user_col_comments where table_name=upper('#{@table}')")

			column_comment = Hash.new
			while(column = rs_comments.fetch_hash) do
				column_comment.store(column["COLUMNNAME"],column["COMMENTS"])
			end

			#ListView.new(column_comment,@clazz,@name,@id,@dpack).write()

			FormJsp.new(column_comment,@name,@id).write()

		end
	end

end

config = YAML.load_file("database.yaml")
CrudModel.new(config["tns"],config["table"],config["domain_pack"],config["crud_pack"],config["author"])




这个文件是生成java代码的主文件,具体的生成代码在相关的模块里面,总体来说,用ruby在做自动生成工具相当的方便,而且ruby本身的设计也相当的优秀。虽然本人以前也学过一段时间的rails,可惜只做过例子,并没有做出什么有实际帮助的东西来。但个人对ruby与rails评价还是很高的,都是些很不错的东西,希望以后能再有机会用到它们。


另外,本人开发使用的scite这个工具。