• <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++博客 :: 首頁(yè) :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
              197 隨筆 :: 3 文章 :: 37 評(píng)論 :: 0 Trackbacks
            /// <summary>
                    /// 根據(jù)時(shí)間生成流水號(hào)
                    /// 流水號(hào)組成如XS200811050001
                    /// XS:銷售
                    /// 20081105:日期
                    /// 0001:20081105日的第一個(gè)訂單
                    /// </summary>
                    /// <returns></returns>
                    private string GetNumberString()
                    {
                        string orderNumber 
            = null;

                        
            //取得當(dāng)天的最大訂單號(hào)
                        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)
                        {
                            
            //如果今天還沒(méi)有訂單
                            orderNumber = "XS" + now.Year.ToString("d4"+ now.Month.ToString("d2"+ now.Day.ToString("d2"+ "0001";
                        }
                        
            else
                        {
                            
            //如果有訂單,則在最大訂單號(hào)上+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版本的自動(dòng)生成有規(guī)則的訂單號(hào)(或編號(hào))
               * 生成的格式是: 200908010001 前面幾位為當(dāng)前的日期,后面五位為系統(tǒng)自增長(zhǎng)類型的編號(hào)
               * 原理:
               *      1.獲取當(dāng)前日期格式化值;
               *      2.讀取文件,上次編號(hào)的值+1最為當(dāng)前此次編號(hào)的值
               *      (新的一天會(huì)重新從1開(kāi)始編號(hào))
               */

            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);
                }
               
                /**
                 * 獲得序列號(hào),同時(shí)更新持久化存儲(chǔ)中的序列
                 * @param current 當(dāng)前的日期
                 * @param start   初始化的序號(hào)
                 * @return 所獲得新的序列號(hào)
                 */
                protected abstract int getOrUpdateNumber(Date current, int start);
            }


            class FileEveryDaySerialNumber extends EveryDaySerialNumber {

                /**
                 * 持久化存儲(chǔ)的文件
                 */   
                private File file = null;
               
                /**
                 * 存儲(chǔ)的分隔符
                 */
                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;
                }
            }

            存儲(chǔ)自動(dòng)編號(hào)值的文件如下(文件名: EveryDaySerialNumber.dat)

             

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



            posted on 2012-02-18 21:06 life02 閱讀(1294) 評(píng)論(0)  編輯 收藏 引用 所屬分類: Android開(kāi)發(fā)
            精品国产乱码久久久久久1区2区| 久久久久无码中| 99久久国产综合精品网成人影院| 精品国产青草久久久久福利| 国产成人精品久久| 久久婷婷久久一区二区三区| 中文字幕无码久久久| 日本三级久久网| 色综合久久久久综合体桃花网| 精品久久久久久久久久中文字幕 | 久久久久亚洲精品日久生情| 国产美女久久精品香蕉69| 亚洲婷婷国产精品电影人久久| www.久久热.com| 精品人妻伦九区久久AAA片69| 亚洲狠狠久久综合一区77777| 99久久夜色精品国产网站 | 国产麻豆精品久久一二三| 伊人久久精品影院| 精品久久久久久无码人妻蜜桃| 99久久婷婷国产综合亚洲| 久久夜色精品国产亚洲| 国产精品无码久久久久| 91精品国产综合久久久久久| 久久天天躁狠狠躁夜夜网站| 精品久久亚洲中文无码| 久久午夜夜伦鲁鲁片免费无码影视| 久久久久久A亚洲欧洲AV冫 | 伊人色综合久久天天网| 欧美粉嫩小泬久久久久久久 | 国产精品日韩深夜福利久久| 国产产无码乱码精品久久鸭| 人妻精品久久无码区| 日本久久久久亚洲中字幕| 色88久久久久高潮综合影院| 久久人妻少妇嫩草AV蜜桃| 狠狠综合久久综合88亚洲| 久久人人爽人人人人爽AV| 亚洲AV无码一区东京热久久| 久久久国产视频| 亚洲va久久久噜噜噜久久天堂 |