• <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 閱讀(1294) 評論(0)  編輯 收藏 引用 所屬分類: Android開發
            久久精品国产亚洲AV麻豆网站 | 久久久久久a亚洲欧洲aⅴ| 久久精品国产网红主播| 久久精品免费观看| 亚洲国产成人久久一区WWW| 欧美午夜精品久久久久免费视| 日本三级久久网| 亚洲国产精品无码久久SM| 国内精品久久久久国产盗摄| 久久狠狠爱亚洲综合影院| 国产一区二区三精品久久久无广告| 伊人精品久久久久7777| 久久国产高清字幕中文| 无码精品久久久久久人妻中字| 国产高清国内精品福利99久久| 久久久久人妻一区二区三区 | 99久久精品免费看国产| 97精品国产97久久久久久免费| 久久久久久a亚洲欧洲aⅴ| 狠狠色婷婷久久一区二区| 精品综合久久久久久88小说| 久久精品中文无码资源站| 久久久久国产精品人妻| 久久这里只精品99re66| 久久精品夜色噜噜亚洲A∨| 狠狠色丁香婷婷久久综合不卡| 色狠狠久久AV五月综合| 亚洲国产精品一区二区久久hs | 免费观看成人久久网免费观看| 久久无码精品一区二区三区| 国产成人精品久久亚洲高清不卡 | 久久狠狠高潮亚洲精品| 久久综合给久久狠狠97色| 久久人人爽人人爽人人AV| 99精品国产99久久久久久97| 亚洲乱码日产精品a级毛片久久| 欧美午夜精品久久久久久浪潮| 精品人妻伦九区久久AAA片69| 久久精品国产亚洲一区二区三区| 国产精品伦理久久久久久| 久久99精品久久久久久不卡 |