AJAX+J2EE开发组织机构管理系统(1)(6)
3. 业务逻辑层的实现
后台开发我们用Java类来实现。这里我们开发了一个orgNew包,类名为orgManager。此类封装了与数据库操作有关的方法。通过main可调试程序的正确性。
这里给出了新增加一个组织的全部代码和通过XML取得树结构信息的代码,树结构通过递归实现。
package orgNew;// Java类所打的包 import tool.*; import java.sql.*; import java.util.*; // 引用Java类的 public class orgManager { public orgManager() { } public static void main(String[] args) throws Exception { Connection conn = tool.ConnTool.getDirectConnection();// 引用数据访问类 conn.setAutoCommit(false); orgManager orgManager1 = new orgManager(); orgManager1.createOrg(0, conn); //测试建立组织是否正确 } //建立一个组织 public static int createOrg(int parentOrgId, Connection conn) throws Exception { String sql = "insert into Org (OrgName, parentOrgId) values('新组织', ?)"; PreparedStatement pstat = conn.prepareStatement(sql); pstat.setInt(1, parentOrgId); pstat.executeUpdate(); pstat.close(); Statement stat = conn.createStatement(); String sql2 = "select max(OrgId) from Org"; ResultSet rs = stat.executeQuery(sql2); rs.next(); int OrgId = rs.getInt(1); rs.close(); stat.close(); System.out.println(OrgId); return OrgId; } } //通过递归得到组织信息的XML格式的数据 public static String getTree(Connection conn) throws Exception { StringBuffer ret = new StringBuffer();//定义可缓冲的字符流 ret.append("<?xml version='1.0' encoding='gb2312'?><tree id='0'>");//定义XML格式的头信息 ret.append(" <item child='1' text='组织' id='1' >");//插入结点体。注树结点以item为标记 ret.append(getChildTree(1, conn)); ret.append("</item>");//结点体结束标记 ret.append("</tree>");//树结束标记 return ret.toString();//返回字符流 } public static String getChildTree(int OrgId, Connection conn) throws Exception { StringBuffer ret = new StringBuffer(); String sql = "select a.OrgId, a.OrgName, a.OrgCode,count(b.parentOrgId) from Org a " + "left join Org b on a.OrgId = b.parentOrgId " + "where a.parentOrgId = ? " + "group by a.OrgId, a.OrgName"; PreparedStatement pstat = conn.prepareStatement(sql); pstat.setInt(1, OrgId); ResultSet rs = pstat.executeQuery(); while (rs.next()) { int childOrgId = rs.getInt(1); String childOrgName = rs.getString(2); String childOrgCode = rs.getString(3); if (childOrgCode == null) { childOrgCode = " "; } if (childOrgName == null) { childOrgName = "新组织"; } int childCount = rs.getInt(3); if (childCount > 0) { childCount = 1; } ret.append("<item child='" + childCount + "' text='" + childOrgName + "' id='" +childOrgId + "' code='"+childOrgCode+"'>"); ret.append(getChildTree(childOrgId, conn)); ret.append("</item>"); } rs.close(); pstat.close(); return ret.toString(); } |
其它代码见orgManager.java文件。
七、 总结
本文件通过一个实例全面介绍了Ajax开发的各个细节。通过与J2ee的结合来实现三层分布式开发的层次划分,后台与前端的调用。数据的读取、访问及展现。
通过这个实例,我们可见,Ajax使WEB中的界面与应用分离。数据与呈现分离的分离,有利于分工合作、减少非技术人员对页面的修改造成的WEB应用程序错误、提高效率、也更加适用于现在的发布系统。也可以把以前的一些服务器负担的工作转嫁到客户端,利于客户端闲置的处理能力来处理。
Ajax是传统WEB应用程序的一个转变。以前是服务器每次生成HTML页面并返回给客户端(浏览器)。Ajax理念的出现,揭开了无刷新更新页面时代的序幕,并有代替传统web开发中采用form(表单)递交方式更新web页面的趋势,可以算是一个里程碑。
总之,Ajax适用于交互较多,频繁读数据,数据分类良好的WEB应用。
(责任编辑:铭铭)