快速业务通道

动态表单及动态建表实现原理 - 编程入门网

作者 佚名技术 来源 NET编程 浏览 发布时间 2012-06-21

动态表单及动态建表实现原理

时间:2011-01-08 blogjava limq

1 应用场景

项目中往往需要动态的创建一个表单,或者添加一个新的数据模板,这时候因为需要在运行时动态的创建表以及动态的维护表字段甚至表关系 使得普通java解决方案变得困难重重。

2 实现工具

Hibernate + Spring + Groovy +Freemarker

Hibernate 作用很简单负责创建数据库表这样可以避免我们自己去写复杂的sql和判断。

Spring 作为桥梁起到连接纽带的作用。

Groovy做为动态语言,在项目运行时根据模板创建访问数据库,或者控制层代码。

Freamker 可以根据提前定义好的模板生成 hibernate配置文件,以及Groovy代码。

3 实现原理

首先创建Form 和 FromAttribute 两张表关系一对多。Form表记录表单的名称,类别,甚至是作为在动态生成表单时的css样式信息。FromAttribute记录表单字段信息,如名称,类别等。有了表单以及表单项的信息后就可以创建数据库表了。

测试代码:

public void testGenerator() {          Form form = formService.getAll().get(0);          List<FormAttribute> list = formAttributeService                  .getAttributeListByFormId(form.getId());          form.setFormAttributeList(list);          DbGenerator dg = new DbGenerator(form, dataSource);          dg.generator();      } DbGenerator import java.io.IOException; import java.io.StringWriter; import java.io.Writer; import java.sql.SQLException; import java.util.HashMap; import java.util.Map; import java.util.Properties; import javax.sql.DataSource; import org.hibernate.tool.hbm2ddl.SchemaExport; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import freemarker.template.Configuration; import freemarker.template.Template; import freemarker.template.TemplateException; public class DbGenerator {      private DataSource dataSource;      protected Map root = new HashMap();      private static Logger log = LoggerFactory.getLogger(FormGenerator.class);      protected String path;      protected String packageName;      private Form form;      protected Configuration getConfig(String resource) {          Configuration cfg = new Configuration();          cfg.setDefaultEncoding("UTF-8");          cfg.setClassForTemplateLoading(this.getClass(), resource);          return cfg;      }      public DbGenerator(Form form ,DataSource dataSource) {          this.form = form;          this.dataSource = dataSource;      }      public void generator() {          if(null == form.getFormAttributeList() || form.getFormAttributeList().size() == 0){              return ;          }          Template t;          try {              t = getConfig("/template").getTemplate("hibernate.ftl");              Writer out = new StringWriter();              t.process(getMapContext(), out);              String xml = out.toString();    

凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

分享到: 更多

Copyright ©1999-2011 厦门凌众科技有限公司 厦门优通互联科技开发有限公司 All rights reserved

地址(ADD):厦门软件园二期望海路63号701E(东南融通旁) 邮编(ZIP):361008

电话:0592-5908028 传真:0592-5908039 咨询信箱:web@lingzhong.cn 咨询OICQ:173723134

《中华人民共和国增值电信业务经营许可证》闽B2-20100024  ICP备案:闽ICP备05037997号