关于计数以及Index返回订单号升级版可以控制年月日累计(不重复)(sqlite)

1数据库创建:

csharp 复制代码
RAGMA foreign_keys = false;

-- ----------------------------
-- Table structure for OrderSIndex
-- ----------------------------
DROP TABLE IF EXISTS "OrderSIndex";
CREATE TABLE "OrderSIndex" (
  "Id" INTEGER NOT NULL PRIMARY KEY AUTOINCREMENT,
  "OrderName" nvarchar(40),
  "OrderIndexInSigle" integer,
  "IndexType" integer,
  "CreateDate" datetime,
  "Updated" datetime,
  "ThisSigle" nvarchar(20)
);

-- ----------------------------
-- Auto increment value for OrderSIndex
-- ----------------------------
UPDATE "sqlite_sequence" SET seq = 4 WHERE name = 'OrderSIndex';

PRAGMA foreign_keys = true;

Model数据:

csharp 复制代码
 /// <summary>
    /// 
    /// </summary>
    public class OrderSIndex
    {

        /// <summary>
        /// 
        /// </summary> 
        [Description("")]
        public int Id { get; set; }
        /// <summary>
        /// 
        /// </summary> 
        [Description("")]
        public string OrderName { get; set; }
        /// <summary>
        /// 
        /// </summary> 
        [Description("")]
        public int OrderIndexInSigle { get; set; }
        /// <summary>
        /// 
        /// </summary> 
        [Description("")]
        public int IndexType { get; set; }
        /// <summary>
        /// 
        /// </summary> 
        [Description("")]
        public DateTime CreateDate { get; set; }
        /// <summary>
        /// 
        /// </summary> 
        [Description("")]
        public DateTime Updated { get; set; }
        /// <summary>
        /// 
        /// </summary> 
        [Description("")]
        public string ThisSigle { get; set; }
    }

DAL操作

csharp 复制代码
 public  class DALOrderSIndex
    {
        /// <summary>
        ///获取当前 0月累计,1日累计,2年累计,3,总共累计
        /// </summary>
        /// <param name="SetNoType"> 0月累计,1日累计,2年累计,3,总共累计</param>
        /// <param name="SetKeyword">当前关键字(需要的表单名子)</param>
        /// <param name="OutIndexLength">index编号长度 0001 就是4 </param>
        /// <returns></returns>
        public string OutIndexStr(string SetKeyword, int SetNoType = 0, int OutIndexLength = 5)
        {
            string ThisSigle;
            switch (SetNoType)
            {
                case 0:
                    ThisSigle = $"{DateTime.Now.Year}{DateTime.Now.ToString("MM")}";
                    break;
                case 1:
                    ThisSigle = DateTime.Now.ToString("yyyyMMdd");
                    break;
                case 2:
                    ThisSigle = DateTime.Now.Year.ToString();
                    break;
                default://3
                    ThisSigle = string.Empty;//数据空
                    break;
            }
            string OutStr;
            string sqlQurey = $"select * from OrderSIndex where OrderName = '{SetKeyword}' and ThisSigle = '{ThisSigle}'";
            string SqlInsert = $"insert into  OrderSIndex (OrderName,OrderIndexInSigle,IndexType,CreateDate,Updated,ThisSigle) values('{SetKeyword}',1,{SetNoType},datetime('now','localtime'),datetime('now','localtime'),'{ThisSigle}')";
            string SqlUpdate = $"Update OrderSIndex set OrderIndexInSigle=OrderIndexInSigle +1 where OrderName = '{SetKeyword}' and ThisSigle = '{ThisSigle}'  ";
            using (IDbConnection Conn = new DALDBBase().GetOpenConn())
            {
                IEnumerable<OrderSIndex> list = Conn.Query<OrderSIndex>(sqlQurey);
                if (list == null || list.Count() == 0)
                {
                    Conn.Execute(SqlInsert);
                    OutStr = $"{ThisSigle}{1.ToString().PadLeft(OutIndexLength, '0')}";
                }
                else
                {
                    Conn.Execute(SqlUpdate);
                    OrderSIndex oneModel = list.FirstOrDefault();
                    OutStr = $"{ThisSigle}{(oneModel.OrderIndexInSigle + 1).ToString().PadLeft(OutIndexLength, '0')}";
                }
            }
            return OutStr; 
        }

    }

使用方法:

csharp 复制代码
 string  innn =  new DAL.DALOrderSIndex().OutIndexStr("功能表数据",3,2);
相关推荐
JSON_L8 小时前
使用 SQLite 创建数据库和表
数据库·sqlite·php
江湖有缘8 小时前
基于华为openEuler部署Sqliteviz轻量级SQLite可视化工具
jvm·华为·sqlite
mahailiang1 天前
codeblocks+wxWidgets Projects中引用第三方库(sqlite3)
数据库·sqlite·wxwidgets·codeblocks
创客小邓1 天前
Qt对SQLite数据库的操作
数据库·qt·sqlite
dreams_dream3 天前
前后端分离项目多环境配置完整笔记
数据库·笔记·sqlite
风清扬_jd3 天前
sqlite支持sqlcipher-4.12.0版本加密编译说明
数据库·c++·sqlite·sqlcipher·sqlite加密
喵手4 天前
Python爬虫实战:快递物流轨迹采集实战:从公开查询到时间线可视化(附CSV导出 + SQLite持久化存储)!
爬虫·python·sqlite·爬虫实战·零基础python爬虫教学·csv导出·快递物流轨迹采集
移幻漂流4 天前
03 - SQLite 技术全景:嵌入式关系数据库引擎完整解析
android·数据库·sqlite
喵手4 天前
Python爬虫实战:论坛社区数据采集实战:从主题列表到分页回帖爬取(附CSV导出 + SQLite持久化存储)!
爬虫·python·sqlite·爬虫实战·零基础python爬虫教学·论坛社区数据采集·csv采集数据导出
喵手4 天前
Python爬虫实战:使用高德地图开放平台API获取餐饮POI数据(店名、坐标、评分)数据采集与地理可视化(附CSV导出 + SQLite持久化存储)!
爬虫·python·sqlite·爬虫实战·零基础python爬虫教学·高德地图开放api·获取餐饮poi数据