码迷,mamicode.com
首页 > 数据库 > 详细

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

时间:2018-11-03 21:08:05      阅读:333      评论:0      收藏:0      [点我收藏+]

标签:数据库   incr   start   current   actor   mss   main   方法   each   

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;
            }
        }
    }
}

 

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

标签:数据库   incr   start   current   actor   mss   main   方法   each   

原文地址:https://www.cnblogs.com/hanstar/p/9901968.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!