生成数据库自增不重复ID的方法

namespace ConsoleApp1
{
    class Program
    {
        static void Main(string[] args)
        {
            var list = new HashSet<string>(101);
            for (int i = 0; i < 100; i++)
            {
                var task = Task.Factory.StartNew((m =>
                {
                    var id = McidGenerator.NewMcid();
                    list.Add(id);
                    Console.WriteLine($"序号:{(int)m + 1}  线程ID:{Thread.CurrentThread.ManagedThreadId} 生成的MCID:{id}");
                }), i);
            }
            Thread.Sleep(10000);
            var n = 1;
            foreach (var li in list.OrderBy(i=>i))
            {
                
                Console.WriteLine($"序号:{(int)n + 1} 生成的MCID:{li}");
                n++;
            }
            Console.ReadLine();
        }
    }

    public static class McidGenerator
    {
        private const int MaxId = 9;
        private static bool _allNew = true;
        private static int _incrementId = 0;
        private static DateTimeOffset _current = DateTimeOffset.Now;
        private static readonly object SequenceLock = new object();

        public static string NewMcid()
        {
            lock (SequenceLock)
            {
                var now = DateTimeOffset.Now;
                if (_allNew)
                {
                    _allNew = false;
                    _current = now;
                    return now.ToString("yyyyMMddHHmmssfffff") + _incrementId;
                }

                if (Convert.ToDateTime(_current.ToString("yyyy-MM-dd HH:mm:ss.fffff")) == Convert.ToDateTime(now.ToString("yyyy-MM-dd HH:mm:ss.fffff")))
                {
                    _incrementId++;
                    _current = now;
                    return now.ToString("yyyyMMddHHmmssfffff") + _incrementId;
                }

                _incrementId++;
                _incrementId = _incrementId > MaxId ? 0 : _incrementId;
                _current = now;
                return now.ToString("yyyyMMddHHmmssfffff") + _incrementId;
            }
        }
    }
}

 

posted @ 2018-11-03 20:26  Microestc-zl  阅读(2785)  评论(0编辑  收藏  举报