随笔 - 7  文章 - 3  trackbacks - 0
<2024年12月>
24252627282930
1234567
891011121314
15161718192021
22232425262728
2930311234

常用链接

留言簿

随笔档案

文章分类

文章档案

搜索

  •  

最新评论

阅读排行榜

评论排行榜

/**
 * 数字转换为大写人民币计数
 * @author 王代军
 * @since Dec 16,2011
 */

public class Num2Rmb
{
    private String[] hanArr = {"零" , "壹" , "贰" , "叁" , "肆" ,
        "伍" , "陆" , "柒" , "捌" , "玖"};
    private String[] unitArr = {"拾","百","千","万"};

    /**
     * 把一个四位的数字字符串变成汉字字符串
     * @param numStr 需要被转换的四位的数字字符串
     * @return 四位的数字字符串被转换成的汉字字符串。
     */
    private String toHanStr(String numStr)
    {
        String result = "";
        int numLen = numStr.length();
        //依次遍历数字字符串的每一位数字
        for (int i = 0 ; i < numLen ; i++ )
        {
            //把char型数字转换成的int型数字,因为它们的ASCII码值恰好相差48
            //因此把char型数字减去48得到int型数字,例如'4'被转换成4。
            int num = numStr.charAt(i) - 48;
            //如果不是最后一位数字,而且数字不是零,则需要添加单位(千、百、十)
            if ( i != numLen - 1 && num != 0)
            {
                result += hanArr[num] + unitArr[numLen - 2 - i];
            }
            //否则不要添加单位
            else
            {
                
                //上一个数是否为“零”,不为“零”时就添加
                if(result.length()>0 && hanArr[num].equals("零") && result.charAt(result.length()-1)=='零')
                    continue;
                result += hanArr[num];
            }
        }
        //只有个位数,直接返回
        if(result.length()==1)
            return result;
        
        int index=result.length()-1;
        while(result.charAt(index)=='零'){
            index--;
        }
        if(index!=result.length()-1)
            return result.substring(0,index+1);
        else {
            return result;
        }
    }
    /**
     * 把一个输入的数字字符串变成汉字字符串
     * @param numStr 需要被转换得到数字字符串
     * @return 数字字符串被转换成的汉字RMB字符串。
     */
    private String toRmbStr(String numStr){
        //获取字符串长度
        int numLen = numStr.length();
        //判断长度小于4(一万以内~0-9999) 调用toHanStr();
        if(numLen<=4){
            return toHanStr(numStr);
        }
        //4<长度<=8 (一亿以内 1000-99999999)
        else if(numLen>4&&numLen<=8){
            String[] subArr={numStr.substring(0, numLen-4),numStr.substring(numLen-4, numLen)};
            return toHanStr(subArr[0])+"万"+toHanStr(subArr[1]);
        }
        //8<长度<=10 (百亿以内 一亿-9999999999)
        else if(numLen>8&&numLen<=10){
            String[] subArr={numStr.substring(0,numLen-8),numStr.substring(numLen-8,numLen-4),numStr.substring(numLen-4,numLen)};
            return toHanStr(subArr[0])+"亿"+toHanStr(subArr[1])+"万"+toHanStr(subArr[2]);
        }
        else return "输入有误!";    
    }          
    public static void main(String[] args)
    {        
        Num2Rmb nr = new Num2Rmb();
        System.out.println("只支持整数(0~99亿)");
        //测试把一个四位的数字字符串变成汉字字符串
        System.out.println(nr.toRmbStr("1"));
        System.out.println(nr.toRmbStr("10"));
        System.out.println(nr.toRmbStr("15"));
        System.out.println(nr.toRmbStr("110"));
        System.out.println(nr.toRmbStr("123"));
        System.out.println(nr.toRmbStr("105"));
        System.out.println(nr.toRmbStr("1000"));
        System.out.println(nr.toRmbStr("1101"));
        System.out.println(nr.toRmbStr("1110"));
        System.out.println(nr.toRmbStr("1005"));
        System.out.println(nr.toRmbStr("101105"));
        System.out.println(nr.toRmbStr("1011109"));
        System.out.println(nr.toRmbStr("9999999999"));
    }
}

posted @ 2011-12-26 13:26 Tomas 阅读(559) | 评论 (0)编辑 收藏
通用的增删该查工具类  可在dao层 new一个
CommonCrudUtil(本类)实例  实现对数据的增删改查




package com.XXXXX.util;

import java.io.Serializable;
import java.util.ArrayList;
import java.util.List;
import org.hibernate.*;
/**
 * 通用增删改查工具类
 * @author 王代军
 * @since Dec 19,2011
 * @version 1.0
 */
@SuppressWarnings("unchecked")
public class CommonCrudUtil<T> {
    /**
     * 添加功能
     * @param obj 要保存的对象
     */
    public boolean create(Object obj){
        Session session=HibernateSessionFactory.getSession();
        Transaction tx=null;
        boolean flag=false;
        try{
            tx=session.beginTransaction();
            session.persist(obj);
            tx.commit();
            flag=true;
        }catch(Exception e){
            e.printStackTrace();
            if(tx!=null){        
                tx.rollback();
            }
        }finally{
            session.close();
        }    
        return flag;
    }
    /**
     * 查询功能
     * @param clazz 要查询对象的类型  obj 要查询的对象的 可序列化的字段 (本设计指主键 id)
     */
    public Object retrieve(Class clazz,Object obj){
        Session session=HibernateSessionFactory.getSession();
        Transaction tx=null;
        try{
            tx=session.beginTransaction();
            Object object=session.get(clazz,(Serializable) obj);
            tx.commit();
            return object;
        }catch(Exception e){
            e.printStackTrace();
            if(tx!=null){        
                tx.rollback();
            }
            return null;
        }finally{
            session.close();
        }        
    }    
    /**
     * 查询全部功能
     * @param clazz 要查询的对象的类型
     */
    public List<T> retrieve(Class clazz){
        Session session=HibernateSessionFactory.getSession();
        List<T> list=new ArrayList<T>();
        Transaction tx=null;
        try{
            tx=session.beginTransaction();
            Criteria cr=session.createCriteria(clazz);
            list=cr.list();
            tx.commit();
            return list;
        }catch(Exception e){
            e.printStackTrace();
            if(tx!=null){            
                tx.rollback();
            }
            return null;
        }finally{
            session.close();
        }
    }
    /**
     * 更新功能
     * @param obj 要更新的对象
     */
    public boolean update(Object obj){
        Session session=HibernateSessionFactory.getSession();
        boolean flag=false;
        Transaction tx=null;
        try{
            tx=session.beginTransaction();
            session.update(obj);
            tx.commit();
            flag=true;
        }catch(Exception e){
            e.printStackTrace();
            if(tx!=null){            
                tx.rollback();
            }
        }finally{
            session.close();
        }
        return flag;
    }
    /**
     * 删除功能
     * @param clazz 要删除的对象的类型 obj 要删除的对象的 唯一标识(可序列化)字段 (指主键 id)
     */
    public boolean delete(Class clazz,Object obj){
        Session session=HibernateSessionFactory.getSession();
        Transaction tx=null;
        boolean flag=false;
        try{
            tx=session.beginTransaction();
            Object object=session.get(clazz,(Serializable) obj);
            session.delete(object);
            tx.commit();
            flag=true;
        }catch(Exception e){
            e.printStackTrace();
            if(tx!=null){        
                tx.rollback();
            }
        }finally{
            session.close();
        }    
        return flag;
    }
    
}



调用实现   dao层的实现类调用 
   CommonCrudUtil  的方法实现增删改查

import java.util.Date;
import java.util.List;

import org.hibernate.Query;
import com.zhongyou.bean.IDCard;
import com.zhongyou.util.CommonCrudUtil;

public class IDCardDaoImpl implements IDCardDaoIf {

    
     CommonCrudUtil crud=new CommonCrudUtil<IDCard>();
   
     public int addInformation(IDCard card) {

     IDCard card=new IDCard();
     card.setId(16);
     card.setName("xiaoxiao");
     card.setAddress("xiaoxiao");
     card.setBirthday(new Date());
     card.setNumber("29472398734");
     card.setSex("男");


     crud.create(card);//增加.......

}
 
     。。。。。。查询。。。。。
     crud.retrieve(IDCard.class,3);
    。。。。。。查询全部。。。。。
     crud.retrieve(IDCard.class);

    。。。。。。修改。。。。
     crud.update(card);
    。。。。。。删除。。。。
     crud.delete(IDCard.class,3);
。。。。。。。。。



写的简陋些  只是些想法可借鉴而已 同志们 可以自己完善。。。。




posted @ 2011-12-26 13:22 Tomas 阅读(2001) | 评论 (1)编辑 收藏
仅列出标题