﻿<?xml version="1.0" encoding="utf-8" standalone="yes"?><rss version="2.0" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:trackback="http://madskills.com/public/xml/rss/module/trackback/" xmlns:wfw="http://wellformedweb.org/CommentAPI/" xmlns:slash="http://purl.org/rss/1.0/modules/slash/"><channel><title>BlogJava-雨天~瀚海驼铃声，欢迎您的到来!-随笔分类-【SSH框架】</title><link>http://www.blogjava.net/1504/category/39422.html</link><description>我在等待中守望着，也在等待中追逐着，守望着我的理想，追逐着我的未来。梦是心的舞台，心有多大，舞台有多大。不轻易服输，不轻言放弃。</description><language>zh-cn</language><lastBuildDate>Tue, 23 Jun 2009 21:05:10 GMT</lastBuildDate><pubDate>Tue, 23 Jun 2009 21:05:10 GMT</pubDate><ttl>60</ttl><item><title>通过GUID生成主键，保证主键全球惟一性【收藏】</title><link>http://www.blogjava.net/1504/archive/2009/06/20/283346.html</link><dc:creator>雨天~瀚海驼铃声</dc:creator><author>雨天~瀚海驼铃声</author><pubDate>Sat, 20 Jun 2009 05:22:00 GMT</pubDate><guid>http://www.blogjava.net/1504/archive/2009/06/20/283346.html</guid><wfw:comment>http://www.blogjava.net/1504/comments/283346.html</wfw:comment><comments>http://www.blogjava.net/1504/archive/2009/06/20/283346.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/1504/comments/commentRss/283346.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/1504/services/trackbacks/283346.html</trackback:ping><description><![CDATA[http://gongstring.javaeye.com/blog/283442<br />
使用GUID作为数据表主键的好处 <br />
　　 <br />
　　使用GUID作为数据表主键的好处 使用GUID作为数据表主键的好处 <br />
　　数据表主健通常采用以下三种方式： <br />
　　1. 自动递增值。 <br />
　　2. 唯一名称。这个是使用自己定义的算法来生成一个唯一序列号。 <br />
　　3. GUID（全局唯一标识符）。 <br />
　　GUID与自动递增值及唯一名称比较GUID在客户端生成，由GUID的特性决定，通过GUID生成的值可能出现重复的机会几乎等于零，因此保证在插入表的时候主键值唯一。 <br />
　　可以方便处理分布式数据的提交，比如：分店数据向总店提交――直接将该部分数据插入即可。 <br />
　　支持离线数据处理。对本地数据包进行新增记录时即可将该数据表的关键字段值赋值，其处理方法是与在线新增时是一致的。 <br />
　　自动递增值 在数据库服务器端生成，由于该值是由数据库系统内部处理的，亦保证其唯一性，但由于其是在数据库服务器端生成，因此必须将该值返回客户端，客户端通过该值过行其它操作。比如一张单据（主从表）是使用自动递增值，当插入单据抬头后，必须将单据抬头的关键字段值返回，再插入单据明细（单据明细是通过单据抬头关键字段进行关联的）。 <br />
　　不能很好处理分布式数据的提交，比如：分店数据向总店提交――提交数据时必须重新生成该数据表的关键字段值，以保证该字段值唯一。 <br />
　　要支持离线数据处理需要进行额外的处理，对本地数据包进行保存记录（保存到本地）时需要插入一个假设唯一值，在提交离线数据回数据服务器时再重新生成真正的唯一值，并重新进行相关的处理。 <br />
　　唯一名称 在客户端生成或在服务端生成，相对于自动递增值不同的地方就是自己维护生成唯一值的算法及所保存的临时值，容易造成出错或其它问题。如果是在客户端生成唯一值的话，还必须保证所生成的值是唯一的。 <br />
　　不能很好处理分布式数据的提交，比如：分店数据向总店提交――提交数据时必须重新生成（或预先处理）该数据表的关键字段值，以保证该字段值唯一 <br />
　　要支持离线数据处理需要进行额外的处理，对本地数据包进行保存记录（保存到本地）时需要插入一个假设唯一值，在提交离线数据回数据服务器时再重新生成真正的唯一值，并重新进行相关的处理。 <br />
　　实例说明下面以一个新增单据保存比较GUID与自动递增值／唯一名称的差别 <br />
　　动作 <br />
　　GUID <br />
　　自动递增值／唯一名称 <br />
　　单据抬头 <br />
　　 <br />
　　新增 <br />
　　单据抬头关键字段值：获取并填写 <br />
　　单据抬头关键字段值：无 <br />
　　保存 <br />
　　直接保存 <br />
　　首先获取并填写关键字段值，然后再进行保存 <br />
　　返回 <br />
　　直接返回 <br />
　　返回时必须将关键字段值返回 <br />
　　单据明细 <br />
　　 <br />
　　新增 <br />
　　关联单据抬头字段值：直接填写 <br />
　　单据明细关键字段值：获取并填写 <br />
　　关联单据抬头字段值：无 <br />
　　单据明细关键字段值：无 <br />
　　保存 <br />
　　直接保存 <br />
　　获取单据抬头关键字段值并填写到单据明细的关联单据抬头字段中； <br />
　　然后获取并填写单据明细关键字段值； <br />
　　再进行保存 <br />
　　 <br />
　　综合以上所述，用GUID作为数据表的关键字段值是可以减轻关键字段相关的操作的，并且是最直接实用的方法。 <br />
<br />
<br />
<br />
<br />
<br />
以下是java中利用GUID生成主键的代码： <br />
<br />
//生成UUID主键import java.util.UUID;&nbsp;&nbsp;&nbsp; <br />
&nbsp;&nbsp; <br />
public class Test {&nbsp;&nbsp;&nbsp; <br />
&nbsp;&nbsp; <br />
&nbsp; public static void main(String[] args) {&nbsp;&nbsp;&nbsp; <br />
&nbsp;&nbsp; <br />
&nbsp;&nbsp;&nbsp; for(int i=0;i&lt;1000;i++){&nbsp;&nbsp;&nbsp; <br />
&nbsp;&nbsp; <br />
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; UUID uuid = UUID.randomUUID();&nbsp;&nbsp;&nbsp;&nbsp; <br />
&nbsp;&nbsp; <br />
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; System.out.println (uuid.toString().replaceAll("-",""));&nbsp;&nbsp;&nbsp; <br />
&nbsp;&nbsp; <br />
&nbsp;&nbsp;&nbsp; }&nbsp;&nbsp;&nbsp; <br />
&nbsp;&nbsp; <br />
&nbsp; }&nbsp;&nbsp;&nbsp; <br />
&nbsp;&nbsp; <br />
} <br />
<img src ="http://www.blogjava.net/1504/aggbug/283346.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/1504/" target="_blank">雨天~瀚海驼铃声</a> 2009-06-20 13:22 <a href="http://www.blogjava.net/1504/archive/2009/06/20/283346.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>struts2中如何获得request.setAttribute("bean", beanObject);的值得在JSP页面显示【自己整理】</title><link>http://www.blogjava.net/1504/archive/2009/06/20/283310.html</link><dc:creator>雨天~瀚海驼铃声</dc:creator><author>雨天~瀚海驼铃声</author><pubDate>Fri, 19 Jun 2009 16:27:00 GMT</pubDate><guid>http://www.blogjava.net/1504/archive/2009/06/20/283310.html</guid><wfw:comment>http://www.blogjava.net/1504/comments/283310.html</wfw:comment><comments>http://www.blogjava.net/1504/archive/2009/06/20/283310.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/1504/comments/commentRss/283310.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/1504/services/trackbacks/283310.html</trackback:ping><description><![CDATA[1.action <br />
<p>public class DataMangAction extends ActionSupport implements ServletRequestAware, ModelDriven&lt;DataMangForm&gt; <br />
{<br />
&nbsp;&nbsp; private String str;<br />
&nbsp;&nbsp; private HttpServletRequest request;<br />
&nbsp;&nbsp; private int pageSize = 2;<br />
&nbsp;&nbsp; private DataMangForm model = new DataMangForm();<br />
&nbsp;&nbsp; <br />
&nbsp;&nbsp;public String execute() throws Exception <br />
&nbsp;&nbsp;{<br />
&nbsp;&nbsp;&nbsp;System.out.println("ok");<br />
&nbsp;&nbsp;&nbsp;str="execute";<br />
&nbsp;&nbsp;&nbsp;return str;<br />
&nbsp;&nbsp;}<br />
&nbsp;&nbsp;public String init() throws Exception <br />
&nbsp;&nbsp;{<br />
&nbsp;&nbsp;&nbsp;DataMangForm dataMangForm = getModel();<br />
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; ArrayList baseInfoList;<br />
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; // 获取当前页码<br />
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; int pageNum = dataMangForm.getPageNum();<br />
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; DataMangOpertion dataMangOpertion=new DataMangOpertion();<br />
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; baseInfoList = dataMangOpertion.getAllBaseInfo(pageSize, pageNum);<br />
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; if (baseInfoList != null) <br />
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; {<br />
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &nbsp;dataMangForm.setBaseInfoList(baseInfoList);<br />
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; Pagination pagination = dataMangOpertion.getPageInAction();<br />
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <br />
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; pagination.setShowCurrentState(true);<br />
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; pagination.setShowPageNumber("dataMangAction!init.action", "", 10, 5);<br />
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; dataMangForm.setPagination(pagination);<br />
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; request.setAttribute("pagination", pagination);<br />
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; }<br />
&nbsp;<br />
&nbsp;&nbsp;&nbsp;str="init";<br />
&nbsp;&nbsp;&nbsp;return str;<br />
&nbsp;&nbsp;}<br />
&nbsp;&nbsp;public String toAdd() throws Exception <br />
&nbsp;&nbsp;{<br />
&nbsp;&nbsp;&nbsp;str="toAdd";<br />
&nbsp;&nbsp;&nbsp;return str;<br />
&nbsp;&nbsp;}<br />
&nbsp;&nbsp;&nbsp;&nbsp; public DataMangForm getModel() <br />
&nbsp;&nbsp;{<br />
&nbsp;&nbsp;&nbsp;return model;<br />
&nbsp;&nbsp;}</p>
<p>&nbsp;&nbsp;&nbsp;&nbsp; public void setServletRequest(HttpServletRequest request)<br />
&nbsp;&nbsp;&nbsp;&nbsp; {<br />
&nbsp;&nbsp;&nbsp;&nbsp; this.request = request;<br />
&nbsp;&nbsp;&nbsp;&nbsp; }<br />
}<br />
2.pagination<br />
</p>
<p>public class Pagination<br />
{</p>
<p>&nbsp; /*<br />
&nbsp; ** pageSize&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 每页记录数<br />
&nbsp; ** recordCount&nbsp;&nbsp; 总记录数<br />
&nbsp; ** pageNum&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 当前页<br />
&nbsp; ** pageCount&nbsp;&nbsp;&nbsp;&nbsp; 总页数<br />
&nbsp; */<br />
&nbsp; private int pageSize;<br />
&nbsp; private int recordCount;<br />
&nbsp; private int pageNum;<br />
&nbsp; private int pageCount;<br />
&nbsp; private String showPageNumber="";<br />
&nbsp; private String showCurrentState;</p>
<p>&nbsp; public Pagination()<br />
&nbsp; {<br />
&nbsp; }<br />
&nbsp; public Pagination(int pageNum,int pageSize,int recordCount,int pageCount)<br />
&nbsp; {<br />
&nbsp;&nbsp;&nbsp; this.setPageNum(pageNum);<br />
&nbsp;&nbsp;&nbsp; this.setPageSize(pageSize);<br />
&nbsp;&nbsp;&nbsp; this.setRecordCount(recordCount);<br />
&nbsp;&nbsp;&nbsp; this.setPageCount(pageCount);<br />
&nbsp; }<br />
&nbsp; public void setPageSize(int pageSize)<br />
&nbsp; {<br />
&nbsp;&nbsp;&nbsp; this.pageSize=pageSize;<br />
&nbsp; }<br />
&nbsp; public int getPageSize()<br />
&nbsp; {<br />
&nbsp;&nbsp;&nbsp; return pageSize;<br />
&nbsp; }<br />
&nbsp; public void setRecordCount(int recordCount)<br />
&nbsp; {<br />
&nbsp;&nbsp;&nbsp; this.recordCount=recordCount;<br />
&nbsp; }<br />
&nbsp; public int getRecordCount()<br />
&nbsp; {<br />
&nbsp;&nbsp;&nbsp; return recordCount;<br />
&nbsp; }<br />
&nbsp; public void setPageNum(int pageNum)<br />
&nbsp; {<br />
&nbsp;&nbsp;&nbsp; this.pageNum=pageNum;<br />
&nbsp; }<br />
&nbsp; public int getPageNum()<br />
&nbsp; {<br />
&nbsp;&nbsp;&nbsp; return pageNum;<br />
&nbsp; }<br />
&nbsp; public void setPageCount(int pageCount)<br />
&nbsp; {<br />
&nbsp;&nbsp;&nbsp; this.pageCount=pageCount;<br />
&nbsp; }<br />
&nbsp; public int getPageCount()<br />
&nbsp; {<br />
&nbsp;&nbsp;&nbsp; return pageCount;<br />
&nbsp; }<br />
&nbsp; //显示分页的当前状态信息<br />
&nbsp; public void setShowCurrentState(boolean bool)<br />
&nbsp; {<br />
&nbsp;&nbsp;&nbsp; if(bool)<br />
&nbsp;&nbsp;&nbsp; {<br />
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; this.showCurrentState = "共有" + recordCount + "条记录数,每页" + pageSize + "条,第&lt;font color=\"red\"&gt;"+ pageNum + "&lt;/font&gt;页,"+"共" +pageCount + "页." ;<br />
&nbsp;&nbsp;&nbsp; }<br />
&nbsp;&nbsp;&nbsp; else<br />
&nbsp;&nbsp;&nbsp; {<br />
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; this.showCurrentState="";<br />
&nbsp;&nbsp;&nbsp; }<br />
&nbsp; }<br />
&nbsp; public String getShowCurrentState()<br />
&nbsp; {<br />
&nbsp;&nbsp;&nbsp; return showCurrentState;<br />
&nbsp; }<br />
&nbsp; //显示分页码<br />
&nbsp; public void setShowPageNumber(String path,String parameters,String first,String previous,String next,String last)<br />
&nbsp; {<br />
&nbsp;&nbsp;&nbsp; if(pageNum&gt;1)<br />
&nbsp;&nbsp;&nbsp; {<br />
&nbsp;&nbsp;&nbsp;&nbsp; showPageNumber="&lt;a href=\"" +path+ "?pageNum=1" +parameters+ "\"&gt;" +first+ "&lt;/a&gt;&amp;nbsp;";<br />
&nbsp;&nbsp;&nbsp;&nbsp; showPageNumber=showPageNumber+"&lt;a href=\"" +path+ "?pageNum=" +(pageNum-1)+parameters+ "\"&gt;" +previous+ "&lt;/a&gt;&amp;nbsp;";<br />
&nbsp;&nbsp; }<br />
&nbsp;&nbsp; if(pageNum&lt;pageCount)<br />
&nbsp;&nbsp; {<br />
&nbsp;&nbsp;&nbsp;&nbsp; showPageNumber=showPageNumber+"&lt;a href=\"" +path+ "?pageNum=" +(pageNum+1)+parameters+ "\"&gt;" +next+ "&lt;/a&gt;&amp;nbsp;";<br />
&nbsp;&nbsp;&nbsp;&nbsp; showPageNumber=showPageNumber+"&lt;a href=\"" +path+ "?pageNum=" +pageCount+parameters+ "\"&gt;" +last+ "&lt;/a&gt;&amp;nbsp;";<br />
&nbsp;&nbsp; }<br />
&nbsp; }<br />
&nbsp; public void setShowPageNumber(String path,String parameters,int middleSize,int kipSize)<br />
&nbsp; {<br />
&nbsp;&nbsp;&nbsp; int start=(pageNum/kipSize)*kipSize+1;<br />
&nbsp;&nbsp;&nbsp; int end=start-1+middleSize;<br />
&nbsp;&nbsp;&nbsp; if(end&gt;=pageCount)<br />
&nbsp;&nbsp;&nbsp; {<br />
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; end=pageCount;<br />
&nbsp;&nbsp;&nbsp; }<br />
&nbsp;&nbsp;&nbsp; if(start&gt;kipSize)<br />
&nbsp;&nbsp;&nbsp; {<br />
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; showPageNumber="&lt;a href=" +path+ "?pageNum=" +(start-2)+parameters+ "&gt;" +"&lt;&lt;&lt;"+ "&lt;/a&gt;&amp;nbsp;";<br />
&nbsp;&nbsp;&nbsp; }<br />
&nbsp;&nbsp;&nbsp; while(start&lt;=end)<br />
&nbsp;&nbsp;&nbsp; {<br />
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; showPageNumber=showPageNumber+"&lt;a href=" +path+ "?pageNum=" +start+parameters+ "&gt;[" +start+ "]&lt;/a&gt;&amp;nbsp;";<br />
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; start++;<br />
&nbsp;&nbsp;&nbsp; }<br />
&nbsp;&nbsp;&nbsp; if(end&lt;pageCount)<br />
&nbsp;&nbsp;&nbsp; {<br />
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; showPageNumber=showPageNumber+"&lt;a href=" +path+ "?pageNum=" +(end+1)+parameters+ "&gt;" +"&gt;&gt;&gt;"+ "&lt;/a&gt;&amp;nbsp;";<br />
&nbsp;&nbsp;&nbsp; }<br />
&nbsp; }<br />
&nbsp; public String getShowPageNumber()<br />
&nbsp; {<br />
&nbsp;&nbsp;&nbsp; return showPageNumber;<br />
&nbsp; }<br />
}</p>
3.在JSP页面显示<br />
&nbsp;${pagination.showPageNumber}&nbsp; ，${pagination.showCurrentState}
<img src ="http://www.blogjava.net/1504/aggbug/283310.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/1504/" target="_blank">雨天~瀚海驼铃声</a> 2009-06-20 00:27 <a href="http://www.blogjava.net/1504/archive/2009/06/20/283310.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item></channel></rss>