kazelee
2025-05-15 1af49bdb3cdaa44a7e44ebdc843fb8180596365f
Helpers/SysHelper.cs
@@ -3,8 +3,12 @@
using SqlSugar;
namespace HH.WCS.Mobox3.DSZSH.Helper {
    /// <summary>
    /// 用于生成序列号,并管理序列号前缀的工具类
    /// </summary>
    internal class SysHelper
    {
        //使用静态 locker 对象实现线程同步
        private static object locker = new object();
        internal static int GetSerialNumber(string snType, string prefix) {
            int result = 0;
@@ -13,9 +17,16 @@
                var sId = db.Queryable<OI_SYS_MAXID>().Where(a => a.CN_S_TYPE.Trim() == snType && a.CN_S_PRE.Trim() == prefix).First();
                if (sId != null) {
                    sId.CN_N_MAX++;
                    if (db.Ado.ExecuteCommand($"update OI_SYS_MAXID set CN_N_MAX={sId.CN_N_MAX} where CN_S_TYPE='{snType}' and CN_S_PRE='{prefix}' ") > 0) {
                    //if (db.Ado.ExecuteCommand($"update OI_SYS_MAXID set CN_N_MAX={sId.CN_N_MAX} where CN_S_TYPE='{snType}' and CN_S_PRE='{prefix}' ") > 0) {
                    //    result = sId.CN_N_MAX;
                    //}
                    // 参数化查询,避免SQL注入
                    if (db.Updateable<OI_SYS_MAXID>().SetColumns(it => it.CN_N_MAX == sId.CN_N_MAX).Where(it => it.CN_S_TYPE == snType
                        && it.CN_S_PRE == prefix).ExecuteCommand() > 0) {
                        result = sId.CN_N_MAX;
                    }
                }
                else {
                    //插入表