RDIFramework.NET V3.3 WinForm版新增訂單管理主從表事例
功能描述
無論什麼系統,除了常規的單表處理外,主從表的應用都是非常普遍的,RDIFramework.NET V3.3 WinForm版本中新增了一個主從表的事例供大家參考。主從表的介面設計大同小異,主要還是在處理CRUD操作時的一些特殊性,如:新增、修改、刪除操作要放在同一事務提交,刪除主表資料,從表對應資料也應相應刪除等。主從表一般涉及兩個以上的表,一個是主表,其他的是從表的,在實際情況下,一般包含兩個表較多,下面我們以兩個表的主從表關係進行分析展示。
訂單管理主從表關係結構圖
功能展示
對於訂單管理主從表結構資訊,主介面展示分為兩部分:一部分是主表資訊,一部分是從表資訊,單擊主表對應資訊後,顯示對應從表的列表資訊,如下圖所示。
新增產品如下圖所示,豐富的控制元件展示,列表直接編輯,自動計算並彙總等實用功能。
列印功能:
核心功能程式碼參考
編輯介面儲存程式碼參考
在編輯介面不僅可以新增資料,還可以編輯資料,呼叫相同的儲存資料的方法。
//儲存資料
private void btnSave_Click(object sender, EventArgs e)
{
if (!this.Changed)
{
//資料未被修改過就直接返回即可
this.DialogResult = DialogResult.OK;
this.Close();
}
else
{
CaseOrderEntity orderEntity = GetFormOrderEntity();
grdOrderDetail.FocusedView.CloseEditor();
var orderDetailList = new List<CaseOrderDetailEntity>();
for (int i = 0; i < this.gridViewOrderDetail.RowCount; i++)
{
var detailInfo = gridViewOrderDetail.GetRow(i) as CaseOrderDetailEntity;
detailInfo.OrderId = orderEntity.Id;
if (detailInfo != null)
{
orderDetailList.Add(detailInfo);
}
}
try
{
int returnValue = caseOrderService.SaveOrder(this.UserInfo, OrderId, orderEntity, orderDetailList);
if (returnValue > 0)
{
MessageBoxHelper.ShowSuccessMsg(RDIFrameworkMessage.MSG0011);
this.DialogResult = DialogResult.OK;
this.Close();
OnFormClosedRefreash?.Invoke();
}
}
catch (Exception ex)
{
ProcessException(ex);
}
}
}
儲存資料服務實現參考
/// <summary>
/// 新增或修改
/// </summary>
/// <param name="userInfo">使用者</param>
/// <param name="keyValue">主鍵值</param>
/// <param name="entity">實體物件</param>
/// <param name="detailEntitys">明細物件</param>
/// <returns></returns>
public int SaveOrder(UserInfo userInfo, string keyValue, CaseOrderEntity entity, List<CaseOrderDetailEntity> detailEntitys)
{
int returnValue = 0;
var parameter = ParameterUtil.CreateWithMessage(userInfo, MethodBase.GetCurrentMethod(), this.serviceName, "SaveOrder-新增或修改");
ServiceUtil.ProcessBusinessDbWithTran(userInfo, parameter, dbProvider =>
{
if (!string.IsNullOrEmpty(keyValue))
{
//主表
var manager = new CaseOrderManager(dbProvider, userInfo);
entity.Id = keyValue;
returnValue = manager.UpdateEntity(entity);
//明細表
var managerDetail = new CaseOrderDetailManager(dbProvider, userInfo);
managerDetail.Delete(new KeyValuePair<string, object>(CaseOrderDetailTable.FieldOrderId, keyValue));
foreach(CaseOrderDetailEntity orderDetail in detailEntitys)
{
orderDetail.OrderId = keyValue;
orderDetail.Enabled = 1;
orderDetail.DeleteMark = 0;
managerDetail.Add(orderDetail);
}
}
else
{
//主表
var manager = new CaseOrderManager(dbProvider, userInfo);
entity.Enabled = 1;
entity.DeleteMark = 0;
string orderKey = manager.Add(entity);
returnValue = string.IsNullOrEmpty(orderKey) ? 0 : 1;
//明細表
var managerDetail = new CaseOrderDetailManager(dbProvider, userInfo);
foreach (CaseOrderDetailEntity orderDetail in detailEntitys)
{
orderDetail.OrderId = orderKey;
orderDetail.Enabled = 1;
orderDetail.DeleteMark = 0;
managerDetail.Add(orderDetail);
}
}
});
return returnValue;
}
參考文章
RDIFramework.NET — 基於.NET的快速資訊化系統開發框架 — 系列目錄
RDIFramework.NET ━ .NET快速資訊化系統開發框架 ━ 工作流程元件介紹
RDIFramework.NET框架SOA解決方案(集Windows服務、WinForm形式與IIS形式釋出)-分散式應用
RDIFramework.NET程式碼生成器全新V3.5版本釋出-重大升級
程式碼生成器下載
一路走來數個年頭,感謝RDIFramework.NET框架的支持者與使用者,大家可以通過下面的地址瞭解詳情。
RDIFramework.NET官方網站:http://www.rdiframework.net/
RDIFramework.NET官方部落格:http://blog.rdiframework.net/
特別說明,框架相關的技術文章請以官方網站為準,歡迎大家收藏!
RDIFramework.NET框架由專業團隊長期打造、一直在更新、一直在升級,請放心使用!
歡迎關注RDIFramework.net框架官方微信公眾號(微訊號:guosisoft),及時瞭解最新動態。
使用微信掃描二維碼立即關注
相關文章
- Thinkphp訂單系統,DukuanCMS競價訂單系統,單品訂單管理系統,多產品訂單管理系統PHP
- MySQL 5.7主從新增新從庫MySql
- WinForm:DataGridView新增加行ORMView
- 從微信查詢訂單狀況
- 圖書管理系統【JavaWeb:使用者、購買、訂單模組、新增許可權】JavaWeb
- Goldengate單表新增同步Go
- STC訂單專案風險管理(轉)
- 日誌管理程式時間訂製版
- 訂單銷貨收款之報表sqlSQL
- STC訂單的多專案管理(轉)專案管理
- 訂單管理系統分析及改進
- 批量提交事例
- WinForm 應用程式的打包和部署_簡單版(圖文)ORM
- 微信支付訂單、退款訂單、轉款訂單的查詢
- Linux環境中MySQL主從同步–新增新的從庫LinuxMySql主從同步
- Helio for mac(音樂創作工具) v3.3免費版Mac
- 新增表單請求後鉤子
- winform之在主窗體中不顯示子窗體的選單欄ORM
- 給Winform中的datagridview新增行號ORMView
- 訂單系統:從0到1設計思路
- Winform DataGridViewTextBoxCell 編輯新增右鍵選單,編輯選中文字ORMView
- 簡單搭建MySQL主從複製MySql
- 資料庫主鍵、從鍵(易懂版)資料庫
- smdms超市訂單管理系統之登入功能
- 向Mysql主鍵自增長表中新增資料並返回主鍵MySql
- html5之新增表單屬性HTML
- 10億級別訂單的分庫分表方案
- MySQL訂單分庫分表多維度查詢MySql
- 從12個方面詳細解讀Pulsar的主題與訂閱
- Window 10 單機配置MYSQL主從同步MySql主從同步
- 簡單配置mysql的主從複製MySql
- Mysql 主-從簡單配置---centos6.4MySqlCentOS
- TableStore實戰:億量級訂單管理解決方案
- WinForm依賴注入簡單使用ORM依賴注入
- shardingjdbc分表分庫,主從分離JDBC
- 360主機衛士Windows版新增黑鏈監控功能Windows
- ava 新增、刪除Excel表單控制元件Excel控制元件
- 常見HTML5新增表單特性演示HTML