• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            life02

              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
              197 隨筆 :: 3 文章 :: 37 評論 :: 0 Trackbacks
            /// <summary>
                    /// 根據時間生成流水號
                    /// 流水號組成如XS200811050001
                    /// XS:銷售
                    /// 20081105:日期
                    /// 0001:20081105日的第一個訂單
                    /// </summary>
                    /// <returns></returns>
                    private string GetNumberString()
                    {
                        string orderNumber 
            = null;

                        
            //取得當天的最大訂單號
                        DateTime now = DateTime.Now;
                        string sql 
            = "select max(convert(int,substring(OrderNumber,11,4))) from Orders where OrderNumber like 'XS" + now.Year.ToString("d4"+ now.Month.ToString("d2"+ now.Day.ToString("d2"+ "%'";

                        DataSet ds 
            = null;
                        using (DatabaseOperater2 op 
            = new DatabaseOperater2())
                        {
                            ds 
            = op.ExcuteSelectByAdater(sql);
                        }

                        
            if (ds.Tables[0].Rows[0][0] is DBNull)
                        {
                            
            //如果今天還沒有訂單
                            orderNumber = "XS" + now.Year.ToString("d4"+ now.Month.ToString("d2"+ now.Day.ToString("d2"+ "0001";
                        }
                        
            else
                        {
                            
            //如果有訂單,則在最大訂單號上+1
                            int number = Convert.ToInt32(ds.Tables[0].Rows[0][0])+1;
                            orderNumber 
            = "XS" + now.Year.ToString("d4"+ now.Month.ToString("d2"+ now.Day.ToString("d2"+ number.ToString("d4");
                        }
                        
            return orderNumber;
                    }

            import java.io.BufferedReader;
            import java.io.BufferedWriter;
            import java.io.File;
            import java.io.FileReader;
            import java.io.FileWriter;
            import java.io.IOException;
            import java.text.DecimalFormat;
            import java.text.SimpleDateFormat;
            import java.util.ArrayList;
            import java.util.Date;
            import java.util.List;
            import java.util.concurrent.TimeUnit;

            /**
               * JAVA版本的自動生成有規則的訂單號(或編號)
               * 生成的格式是: 200908010001 前面幾位為當前的日期,后面五位為系統自增長類型的編號
               * 原理:
               *      1.獲取當前日期格式化值;
               *      2.讀取文件,上次編號的值+1最為當前此次編號的值
               *      (新的一天會重新從1開始編號)
               */

            public class Test01 {
               
                public static void main(String[] args) throws InterruptedException {
                    SerialNumber serial = new FileEveryDaySerialNumber(5, "EveryDaySerialNumber.dat");
                    while(true) {
                        System.out.println(serial.getSerialNumber());
                        TimeUnit.SECONDS.sleep(2);
                    }
                }
            }


            abstract class SerialNumber {

                public synchronized String getSerialNumber() {
                    return process();
                }
                protected abstract String process();
            }


            abstract class EveryDaySerialNumber extends SerialNumber {
               
                protected final static SimpleDateFormat sdf = new SimpleDateFormat("yyyyMMdd");
                protected DecimalFormat df = null;
               
                public EveryDaySerialNumber(int width) {
                    if(width < 1) {
                        throw new IllegalArgumentException("Parameter length must be great than 1!");
                    }
                    char[] chs = new char[width];
                    for(int i = 0; i < width; i++) {
                        chs[i] = '0';
                    }
                    df = new DecimalFormat(new String(chs));
                }
               
                protected String process() {
                    Date date = new Date();
                    int n = getOrUpdateNumber(date, 1);
                    return format(date) + format(n);
                }
               
                protected String format(Date date) {
                    return sdf.format(date);
                }
                protected String format(int num) {
                    return df.format(num);
                }
               
                /**
                 * 獲得序列號,同時更新持久化存儲中的序列
                 * @param current 當前的日期
                 * @param start   初始化的序號
                 * @return 所獲得新的序列號
                 */
                protected abstract int getOrUpdateNumber(Date current, int start);
            }


            class FileEveryDaySerialNumber extends EveryDaySerialNumber {

                /**
                 * 持久化存儲的文件
                 */   
                private File file = null;
               
                /**
                 * 存儲的分隔符
                 */
                private final static String FIELD_SEPARATOR = ",";   

                public FileEveryDaySerialNumber(int width, String filename) {
                    super(width);
                    file = new File(filename);
                }

                @Override
                protected int getOrUpdateNumber(Date current, int start) {
                    String date = format(current);
                    int num = start;
                    if(file.exists()) {
                        List<String> list = FileUtil.readList(file);       
                        String[] data = list.get(0).split(FIELD_SEPARATOR);
                        if(date.equals(data[0])) {
                            num = Integer.parseInt(data[1]);
                        }
                    }
                    FileUtil.rewrite(file, date + FIELD_SEPARATOR + (num + 1));
                    return num;
                }       
            }


            class FileUtil {

                public static void rewrite(File file, String data) {
                    BufferedWriter bw = null;
                    try {
                        bw = new BufferedWriter(new FileWriter(file));
                        bw.write(data);
                    } catch (IOException e) {
                        e.printStackTrace();
                    } finally {       
                        if(bw != null) {
                           try {
                               bw.close();
                           } catch(IOException e) {
                               e.printStackTrace();
                           }
                        }           
                    }
                }
               
                public static List<String> readList(File file) {
                    BufferedReader br = null;
                    List<String> data = new ArrayList<String>();
                    try {
                        br = new BufferedReader(new FileReader(file));
                        for(String str = null; (str = br.readLine()) != null; ) {
                            data.add(str);
                        }
                    } catch (IOException e) {
                        e.printStackTrace();
                    } finally {
                        if(br != null) {
                           try {
                               br.close();
                           } catch(IOException e) {
                               e.printStackTrace();
                           }
                        }
                    }
                    return data;
                }
            }

            存儲自動編號值的文件如下(文件名: EveryDaySerialNumber.dat)

             

            原文地址:http://hi.baidu.com/itlangqun/blog/item/24a490838d4c7fb66c8119fd.html



            posted on 2012-02-18 21:06 life02 閱讀(1298) 評論(0)  編輯 收藏 引用 所屬分類: Android開發
            婷婷久久综合九色综合绿巨人 | 国产69精品久久久久99| 91精品国产9l久久久久| 99精品国产在热久久无毒不卡| 国产精品久久久久久久| 国产激情久久久久影院| 日日狠狠久久偷偷色综合96蜜桃| 久久99热这里只有精品66| 99精品久久久久久久婷婷| 国产精品久久久久久影院| 久久精品国产第一区二区| 无码八A片人妻少妇久久| 成人免费网站久久久| 亚洲AV伊人久久青青草原| 精品熟女少妇a∨免费久久| 色偷偷88欧美精品久久久| 精品久久久久久亚洲精品| 久久毛片免费看一区二区三区| 久久人人爽人人爽人人片av麻烦| 久久精品九九亚洲精品| 久久久久一本毛久久久| 九九精品99久久久香蕉| 色偷偷偷久久伊人大杳蕉| 看全色黄大色大片免费久久久| 99麻豆久久久国产精品免费| 一本色综合网久久| 久久人人爽人爽人人爽av| 成人午夜精品久久久久久久小说| 亚洲精品乱码久久久久久蜜桃图片| 国产一区二区精品久久凹凸| 国产精品对白刺激久久久| 精品久久久无码人妻中文字幕| 精品久久人人爽天天玩人人妻 | 国内精品伊人久久久久AV影院| 少妇被又大又粗又爽毛片久久黑人| 久久久久久久综合日本亚洲| 久久久精品人妻一区二区三区蜜桃| 久久亚洲国产精品成人AV秋霞| 无码8090精品久久一区| 亚洲国产成人久久精品99 | 久久婷婷五月综合97色直播|