权限管理、用户权限系统、开源用户权限系统、信息化建设标准基础数据管理平台
代码改变世界

C#.NET 大型通用信息化系统集成快速开发平台 4.1 版本 - 主细表事务处理的标准例子

  通用C#系统架构  阅读(2436)  评论(2编辑  收藏  举报

要么就一次全成功,要么就一次全失败,插入主表的同时插入关联的子表,主表插入时返回当前插入的主键,字表插入时用这个主键做关联。

参考代码如下:

复制代码
        /// <summary>
        /// 添加角色(同时添加用户,一个数据库事务里进行处理)
        /// </summary>
        /// <param name="userInfo">用户</param>
        /// <param name="entity">实体</param>
        /// <param name="userIds">用户主键数组</param>
        /// <param name="statusCode">返回状态码</param>
        /// <param name="statusMessage">返回状态信息</param>
        /// <returns>主键</returns>
        public string AddWithUser(BaseUserInfo userInfo, BaseRoleEntity entity, string[] userIds, out string statusCode, out string statusMessage)
        {
            var parameter = ServiceParameter.CreateWithMessage(userInfo
                , MethodBase.GetCurrentMethod()
                , this.serviceName
                , AppMessage.RoleService_Add);

            string result = string.Empty;
            string returnCode = string.Empty;
            string returnMessage = string.Empty;
            ServiceUtil.ProcessUserCenterWriteDbWithTransaction(userInfo, parameter, (dbHelper) =>
            {
                // 这里是判断已经登录的用户是否有调用当前函数的权限,加强服务层被远程调用的安全性的
                var permissionManager = new BasePermissionManager(userInfo);
                if (permissionManager.CheckPermissionByUser(userInfo.Id, "RoleAdmin.Add", "添加角色"))
                {
                    string tableName = userInfo.SystemCode + "Role";
                    var manager = new BaseRoleManager(dbHelper, userInfo, tableName);
                    result = manager.Add(entity, out returnCode);
                    if (!string.IsNullOrEmpty(result) && userIds != null && userIds.Length > 0)
                    {
                        tableName = userInfo.SystemCode + "UserRole";
                        var userManager = new BaseUserManager(dbHelper, userInfo, tableName);
                        // 小心异常,检查一下参数的有效性
                        if (userIds != null)
                        {
                            userManager.AddToRole(userIds, result);
                        }
                    }
                    returnMessage = manager.GetStateMessage(returnCode);
                }
            });
            statusCode = returnCode;
            statusMessage = returnMessage;
            return result;
        }
复制代码

 

 

编辑推荐:
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
阅读排行:
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!
历史上的今天:
2011-02-25 C#.NET通用管理系统后台管理组件中选择组织机构选择功能增加默认选择内部组织机构的功能
2011-02-25 组织机构管理里只有“内部组织”会出现在即时通讯的目录树里(可供C#.NET源码下载学习)


C# ASP.NET 通用权限设计、通用权限管理、通用权限组件、单点登录、集中式权限管理、统一授权体系、分级管理分级授权


微信扫一扫加好友



点击右上角即可分享
微信分享提示