最新文章 (全部类别)
CSFrameworkV6.1旗舰版 - appsettings.json 配置文件增加参数
推荐:使用Photoshop制作ico图标
C#.NET格式化显示:数字末尾不显示0
SQL脚本:更新主表的完成标记FlagFinish=Y
FastReport.NET 设计器汉化&运行时汉化
VS2026/VS2022 关闭 “自动添加 using 命名空间”
C#将List<T>导出为 CSV 文件(Excel 直接打开,无需第三方组件包)
.NET8+EF.Core开发的大型ERP系统客户端4GB电脑测试报告
线联ERP - LinERP HR+考勤系统正式上线
CSFrameworkV6旗舰版 - 复制单据功能
QMS软件简介 | 成本核算报价系统软件简介
QMS - 五金制品行业成本核算报价系统 - 货币资料
QMS - 五金制品行业成本核算报价系统 - 公共字典管理
QMS - 五金制品行业成本核算报价系统 - 物料类别
QMS - 五金制品行业成本核算报价系统 - 物料管理
QMS - 五金制品行业成本核算报价系统 - 图纸文件管理
QMS - 五金制品行业成本核算报价系统 - 供应商管理
QMS - 五金制品行业成本核算报价系统 - 车型费管理
QMS - 五金制品行业成本核算报价系统 - 制程段配置
QMS - 五金制品行业成本核算报价系统 - 产品咨询
QMS五金制品行业报价系统 - 用户操作手册 - 成本中心核算
QMS五金制品行业报价系统 - 用户操作手册 - 报价单 - Quotation
QMS五金制品行业报价系统 - 用户操作手册 - 成本汇总表
QMS五金制品行业报价系统 - 用户操作手册 - 采购评估
QMS五金制品行业报价系统 - 用户操作手册 - 成本基础资料表
QMS五金制品行业报价系统 - 用户操作手册 - 新品可行性评估
QMS - 成本核算报价管理系统软件截图
QMS五金制品行业报价系统 - 用户操作手册 - 业务员管理
QMS五金制品行业报价系统 - 用户操作手册 - 客户管理
QMS五金制品行业报价系统 - 用户操作手册 - 工艺工序维护
QMS五金制品行业报价系统 - 用户操作手册 - 设备登记
C# 使用 FluentFTP 下载文件提示乱码
DevExpress GridControl 主从表数据(Master/Detail) 应用 - 高级篇
制造行业ERP人工成本核算表
C# 把 List<T> 指定属性的值,赋值给目标对象(列转行)
C#.NET反射给对象赋值(使用TypeConverter类转换)
使用数据日志(sys_LogData)保存数据同步标记
开发框架工具栏按钮图标
ERP操作手册-表格的列被隐藏
ERP集成海康威视考勤机及导入考勤记录技术方案(原创)
FastReport.NET+.NET8高级开发篇:明细表打印图片,自动行高
框架升级:业务单据查询结果显示2种方式(显示主表、序时薄)
CSFrameworkV6最新功能:表格样式存储位置(Database=数据库,Local=本地文件)
FastReport.NET 设置报表字体平滑清晰度
C# LINQ踩坑日记:数据库存的字符串null 和 "" 是两个不同的值,所以 GroupBy 会分成两组
SQL Server主从表字段拼接更新
删除SQL登录名提示:无法删除登录名,因为该用户目前正处于登录状态
SQL Server 代理服务无法启动与修复
Windows Event Log事件日志服务无法启动与修复
锐捷(Ruijie / 睿易)EWeb 管理系统无线路由器WiFi固定MAC地址与IP
.net敏捷开发,创造卓越

C/S开发框架新功能:批量更新业务单据的业务员、制单人制表人


  C/S开发框架新功能:批量更新业务单据的业务员、制单人制表人
C/S开发框架新功能:批量更新业务单据的业务员、制单人制表人


业务员或系统操作人员(系统登录用户)离职后,需要把相关数据资料移交给其他同事维护,同时将原数据备份好,便于后期查阅历史数据。最近新开发以下两个功能给大家参考:


1. 批量更新用户

批量更新用户信息,对应业务单据的制单人、制表人,同时要更新最后修改人信息。


2. 批量更新业务员

批量更新业务单据的业务员资料,比如《报价单》、《采购单》、《销售单》等关联的业务员信息。




修改业务员:


贴图图片-批量更新业务员


贴图图片-批量更新业务员 (2)


贴图图片-批量更新业务员 (3)



《业务员管理》界面的扩展按钮:


C# Code:

public override void InitButtons()
{
  
base.InitButtons();
  
  IButtonInfo btnUpdateSales
= this.ToolbarRegister.CreateButton("btnUpdateSales",
  
"改业务员", ToolBarGroup.数据操作, Globals.LoadBitmap("32_Refresh.png"), new Size(57, 28), true, true, this.UpdateSales);
  _buttons.AddButton(btnUpdateSales);
  
}
public virtual void UpdateSales(IButtonInfo sender)
{
  
this.AssertFocusedRow();
  
object sales = gvSummary.GetFocusedRowCellValue(colSalesCode);
  frmSalesUpdate.Execute(sales);
}


//来源:C/S框架网 | www.csframework.com | QQ:23404761



DAL层:


C# Code:

public int SalesUpdate(string oldSales, string newSales)
{
  
  CommandHelper cmd
= _Database.CreateSqlProc("usp_UpdateSales");
  cmd.AddParam(
"@OldSales", DbType.String, oldSales);
  cmd.AddParam(
"@NewSales", DbType.String, newSales);
  
object o = _Database.ExecuteScalar(cmd.Command);
  
  
return ConvertEx.ToInt(o);
}

//来源:C/S框架网 | www.csframework.com | QQ:23404761



SQL存储过程:


SQL Code:

USE [NN_OMS_Business]
GO
/****** Object: StoredProcedure [dbo].[usp_UpdateSales] Script Date: 09/16/2020 10:27:50 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
ALTER PROCEDURE [dbo].[usp_UpdateSales]
  
@OldSales VARCHAR(20), --旧业务员
  
@NewSales VARCHAR(20), --新业务员
  
@OperateUser VARCHAR(20)='' --当前操作用户,如:admin
AS
BEGIN
  
  
/******************************************************
  程序说明:更改业务单据的业务员资料
  
  -------------------------------------------------------
  SELECT * FROM dbo.dt_Sales
  SELECT * FROM NN_System.dbo.sys_LogOperation
  
  -------------------------------------------------------
  usp_UpdateSales 'admin','admin'
  usp_UpdateSales 'admin','000'
  usp_UpdateSales '000','admin'
  
  ******************************************************
*/
  
  
DECLARE @MSG NVARCHAR(200)
  
  
--检查数据拥有者是否当前用户
  
IF ISNULL(@NewSales,'')='' OR @NewSales=@OldSales
  
BEGIN
  
SELECT @MSG='新业务员不能为空,并且不能与原有业务员相同!';
  
RAISERROR (@MSG,16,1);
  
RETURN;
  
END;
  
  
DECLARE @Count INT
  
  
UPDATE dbo.tb_QO SET Sales=@NewSales WHERE Sales=@OldSales
  
SELECT @Count=ISNULL(@Count,0)+@@ROWCOUNT;
  
  
UPDATE dbo.tb_PI SET Sales=@NewSales WHERE Sales=@OldSales
  
SELECT @Count=ISNULL(@Count,0)+@@ROWCOUNT;
  
  
UPDATE dbo.tb_IV SET Sales=@NewSales WHERE Sales=@OldSales
  
SELECT @Count=ISNULL(@Count,0)+@@ROWCOUNT;
  
  
UPDATE dbo.tb_PF SET Sales=@NewSales WHERE Sales=@OldSales
  
SELECT @Count=ISNULL(@Count,0)+@@ROWCOUNT;
  
  
--添加删除日志
  
INSERT INTO NN_System.dbo.sys_LogOperation(OperationType,OperationTime,Account,MSG)
  
SELECT 'Update',GETDATE(),@OperateUser,'变更《业务员》,旧:'+@OldSales+'新:'+@NewSales;
  
  
SELECT @Count AS UpdatedRows
  
  
END;
  
  
//来源:C/S框架网 | www.csframework.com | QQ:23404761








修改用户、制单人、制表人:


贴图图片-批量更新用户


贴图图片-批量更新用户 (2)



《用户管理》界面的扩展按钮:


C# Code:

public override void InitButtons()
{
  
base.InitButtons();
  
  
if (ButtonAuthorized(ButtonAuthority.CLONE))
  {
    IButtonInfo btnCopyPermission
= this.ToolbarRegister.CreateButton("btnCopyPermission", "复制权限", ToolBarGroup.扩展功能1,
    Resources._2009011340768021,
new Size(57, 28), true, true, this.DoCopyPermission);
    _buttons.AddButton(btnCopyPermission);
    
    IButtonInfo btnUpdateUser
= this.ToolbarRegister.CreateButton("btnUpdateUser",
    
"更改用户", ToolBarGroup.数据操作, Globals.LoadBitmap("32_Refresh.png"), new Size(57, 28), true, true, this.UpdateUser);
    _buttons.AddButton(btnUpdateUser);
  }
}


private void UpdateUser(IButtonInfo sender)
{
  
this.AssertFocusedRow();
  
object user = gvSummary.GetFocusedRowCellValue(colAccount);
  frmUserUpdate.Execute(user);
}

//来源:C/S框架网 | www.csframework.com | QQ:23404761



DAL层:


C# Code:

public int UpdateUser(string oldUser, string newUser)
{
  IDatabase db
= DatabaseProvider.GetDatabase(Loginer.CurrentUser.DBID);
  
  CommandHelper cmd
= db.CreateSqlProc("usp_UpdateCreateBy");
  cmd.AddParam(
"@OldUser", DbType.String, oldUser);
  cmd.AddParam(
"@NewUser", DbType.String, newUser);
  cmd.AddParam(
"@OperateUser", DbType.String, Loginer.CurrentUser.Account);
  
object o = db.ExecuteScalar(cmd.Command);
  
  
return ConvertEx.ToInt(o);
}

//来源:C/S框架网 | www.csframework.com | QQ:23404761




SQL存储过程:



SQL Code:

USE [NN_OMS_Business]
GO
/****** Object: StoredProcedure [dbo].[usp_UpdateCreateBy] Script Date: 09/16/2020 10:29:33 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
ALTER PROCEDURE [dbo].[usp_UpdateCreateBy]
  
@OldUser VARCHAR(20), --旧用户
  
@NewUser VARCHAR(20), --新用户
  
@OperateUser VARCHAR(20)='' --当前操作用户,如:admin
AS
BEGIN
  
  
/******************************************************
  程序说明:更改业务单据的制单人资料
  
  -------------------------------------------------------
  SELECT * FROM dbo.dt_Sales
  SELECT * FROM NN_System.dbo.sys_LogOperation
  
  -------------------------------------------------------
  usp_UpdateCreateBy 'admin','admin'
  usp_UpdateCreateBy '111','000'
  usp_UpdateCreateBy '000','111'
  
  ******************************************************
*/
  
  
DECLARE @MSG NVARCHAR(200)
  
  
--检查数据拥有者是否当前用户
  
IF ISNULL(@NewUser,'')='' OR @NewUser=@OldUser
  
BEGIN
  
SELECT @MSG='新用户不能为空,并且不能与原有用户相同!';
  
RAISERROR (@MSG,16,1);
  
RETURN;
  
END;
  
  
DECLARE @Count INT
  
  
--更新主表
  
UPDATE dbo.tb_QO SET CreatedBy=@NewUser,LastUpdatedBy=@NewUser WHERE CreatedBy=@OldUser
  
SELECT @Count=ISNULL(@Count,0)+@@ROWCOUNT;
  
--更新明细表
  
UPDATE dbo.tb_QOs SET LastUpdatedBy=@NewUser WHERE LastUpdatedBy=@OldUser
  
  
UPDATE dbo.tb_PI SET CreatedBy=@NewUser,LastUpdatedBy=@NewUser WHERE CreatedBy=@OldUser
  
SELECT @Count=ISNULL(@Count,0)+@@ROWCOUNT;
  
UPDATE dbo.tb_PIs SET LastUpdatedBy=@NewUser WHERE LastUpdatedBy=@OldUser
  
  
UPDATE dbo.tb_IV SET CreatedBy=@NewUser,LastUpdatedBy=@NewUser WHERE CreatedBy=@OldUser
  
SELECT @Count=ISNULL(@Count,0)+@@ROWCOUNT;
  
UPDATE dbo.tb_IVs SET LastUpdatedBy=@NewUser WHERE LastUpdatedBy=@OldUser
  
  
UPDATE dbo.tb_PF SET CreatedBy=@NewUser,LastUpdatedBy=@NewUser WHERE CreatedBy=@OldUser
  
SELECT @Count=ISNULL(@Count,0)+@@ROWCOUNT;
  
UPDATE dbo.tb_PFs SET LastUpdatedBy=@NewUser WHERE LastUpdatedBy=@OldUser
  
  
UPDATE dbo.tb_PL SET CreatedBy=@NewUser,LastUpdatedBy=@NewUser WHERE CreatedBy=@OldUser
  
SELECT @Count=ISNULL(@Count,0)+@@ROWCOUNT;
  
UPDATE dbo.tb_PLs SET LastUpdatedBy=@NewUser WHERE LastUpdatedBy=@OldUser
  
  
UPDATE dbo.tb_PM SET CreatedBy=@NewUser,LastUpdatedBy=@NewUser WHERE CreatedBy=@OldUser
  
SELECT @Count=ISNULL(@Count,0)+@@ROWCOUNT;
  
UPDATE dbo.tb_PMs SET LastUpdatedBy=@NewUser WHERE LastUpdatedBy=@OldUser
  
  
UPDATE dbo.tb_PO SET CreatedBy=@NewUser,LastUpdatedBy=@NewUser WHERE CreatedBy=@OldUser
  
SELECT @Count=ISNULL(@Count,0)+@@ROWCOUNT;
  
UPDATE dbo.tb_POs SET LastUpdatedBy=@NewUser WHERE LastUpdatedBy=@OldUser
  
  
--添加删除日志
  
INSERT INTO NN_System.dbo.sys_LogOperation(OperationType,OperationTime,Account,MSG)
  
SELECT 'Update',GETDATE(),@OperateUser,'变更《制单人》,旧:'+@OldUser+'新:'+@NewUser;
  
  
SELECT @Count AS UpdatedRows
  
  
END;
  
  
//来源:C/S框架网 | www.csframework.com | QQ:23404761




C/S系统快速开发框架旗舰版V5.0(Ultimate Edition)

适用开发 适用开发:制造、服务、零售、商贸等行业的ERP、MRP、MES、CRM、MIS、HIS、POS数据管理应用系统
运行平台 运行平台:Windows + .NET Framework 4.5
开发工具 开发工具:Visual Studio 2015+,C#语言
数据库 数据库:Microsoft SQLServer 2008R2+(支持多数据库:Oracle/MySql)

C/S系统开发框架旗舰版V5.0

 产品介绍 

    C/S系统开发框架旗舰版为软件团队提供强大的技术支撑以及快速开发能力,开发框架集成大量的通用开发包与工具实用类,提供丰富的例子,借助技术文档、网站资源、演示源码以及在线技术指导,用户能快速投入研发自己的项目。自2007年首发开发框架以来,我们成功积累了2000多位用户,其中包括数百家软件公司或大型集团企业。经过十年的产品迭代升级,最新旗舰版技术更成熟,性能更稳定,产出效率更高!

    配套的代码生成器工具能自动生成界面(FORM)、业务层(BLL)、数据层(DAL)、模型(Model)、报表(Report)以及业务模块(Class Library DLL)的源代码,极大地提高开发效率、节约开发时间、降低项目成本。据多年项目实践统计,开发框架基本能完成项目大概60%以上的工作量。


开发框架旗舰版V5详情:http://www.csframework.com/cs-framework-5.0.htm


C/S框架网|原创精神.创造价值.打造精品

扫一扫加微信
C/S框架网作者微信 C/S框架网|原创作品.质量保障.竭诚为您服务



版权声明:本文为开发框架文库发布内容,转载请附上原文出处连接
C/S框架网
上一篇:BLL层_DataBinder对象以及_DataBinder.Rows[0].EndEdit方法详解
下一篇:使用WebApi框架开发微信小程序后端程序详细设计说明书模板docx文件
评论列表

发表评论

评论内容
昵称:
关联文章

C/S开发框架功能批量更新业务单据业务员单人制表
C/S快速开发框架旗舰版V5.1 - 业务单据窗体开发步骤
CS开发框架 - 业务单据自动生成功能设计(原)
开发框架旗舰版V5支持单人多选查询以及组织架构权限查询数据
四.业务单据窗体开发步骤-业务单据窗体-C/S快速开发框架-标准版V2.3
C/S快速开发框架旗舰版V5.1 - 业务单据主表字段命名规范
C/S架构轻量级快速开发框架 - WinFrameworkV2.1 功能 (2021)
开发技巧-Winform窗体自动生成下一个业务流程单据|C/S框架
业务单据上下级权限控制实现
C/S快速开发框架旗舰版V5.1 - 业务单据明细表字段命名规范
C/S快速开发框架旗舰版V5.1 - 业务单据窗体开发实例-销售订单表结构设计
C/S快速开发框架旗舰版V5.1 - 业务单据窗体基类介绍
使用bllBaseDataDict类提交业务单据(主从表)明细表实例|C/S框架
使用FastReport做报表实战-报表模块开发框架
C# Winform 开发平台功能 - C/S系统开发框架旗舰版V5.0
一.业务单据窗体基类介绍-业务单据窗体-C/S快速开发框架-标准版V2.3
C# Winform 开发框架 - 业务单据附件管理解决方案(原)
CS开发框架Toolbar与数据字典,业务单据关系
CSFrameworkV6旗舰版 - 业务单据复制功能,支持复制多级明细表
C/S架构软件开发平台 - 旗舰版V6.1 - 功能汇总

热门标签
软件著作权登记证书 .NET .NET Reactor .NET5 .NET6 .NET7 .NET8 .NET9 .NETFramework AI编程 APP AspNetCore AuthV3 Auth-软件授权注册系统 Axios B/S B/S开发框架 B/S框架 BSFramework Bug Bug记录 C#加密解密 C#源码 C/S CHATGPT CMS系统 CodeGenerator CSFramework.DB CSFramework.EF CSFramework.License CSFrameworkV1学习版 CSFrameworkV2标准版 CSFrameworkV3高级版 CSFrameworkV4企业版 CSFrameworkV5旗舰版 CSFrameworkV6.0 CSFrameworkV6.1 CSFrameworkV6旗舰版 DAL数据访问层 DaMeng Database datalock DbFramework DeepSeek Demo教学 Demo实例 Demo下载 DevExpress教程 Docker Desktop DOM ECS服务器 EFCore EF框架 Element-UI EntityFramework ERP ES6 Excel FastReport GIT HR HR考勤系统 IDatabase IIS JavaScript LINQ MES MiniFramework MIS MSSQL MySql NavBarControl NETCore Node.JS NPM OMS Oracle资料 ORM PaaS POS PostgreSql Promise API PSD QMS RedGet Redis RSA SAP Schema SEO SEO文章 SQL SQLConnector SQLite SqlServer Swagger TMS系统 Token令牌 VS2022 VSCode VS升级 VUE WCF WebApi WebApi NETCore WebApi框架 WEB开发框架 Windows服务 Winform 开发框架 Winform 开发平台 WinFramework Workflow工作流 Workflow流程引擎 XtraReport 安装环境 版本区别 报表 备份还原 踩坑日记 操作手册 成本核算系统 达梦数据库 代码生成器 电子线材ERP 迭代开发记录 功能介绍 官方软件下载 国际化 海康威视考勤 基础资料窗体 架构设计 角色权限 开发sce 开发工具 开发技巧 开发教程 开发框架 开发平台 开发指南 客户案例 快速搭站系统 快速开发平台 框架升级 毛衫行业ERP 秘钥 密钥 企业网络维护 权限设计 软件报价 软件测试报告 软件加壳 软件简介 软件开发框架 软件开发平台 软件开发文档 软件授权 软件授权注册系统 软件体系架构 软件下载 软件著作权登记证书 软著证书 三层架构 设计模式 生成代码 实用小技巧 视频下载 收钱音箱 数据锁 数据同步 塑木地板行业ERP 推荐软件 微信小程序 未解决问题 文档下载 喜鹊ERP 喜鹊软件 系统对接 线联ERP 详细设计说明书 新功能 信创 行政区域数据库 需求分析 疑难杂症 蝇量级框架 蝇量框架 用户管理 用户开发手册 用户控件 在线支付 纸箱ERP 智能语音收款机 自定义窗体 自定义组件 自动升级程序
联系我们
联系电话:13923396219(微信同号)
电子邮箱:23404761@qq.com
站长微信二维码
微信二维码