750 likes | 1.19k Views
EEP2006 基礎教學講義. Andy Kao. 課程大綱 ( 一 ). 課程大綱 ( 二 ). 課程大綱 ( 三 ). .NET & VS2005. .NET 的架構. VS 2005 (C#,VB,J#..). WinForm. ASP.NET. Base Class Library. CLR ( Common Language Runtime ). Windows. 認識 .NET. 是一個高階平台,不是個 OS 是一個方便於程式師的開發平台 更強的 VM 虛擬機概念 ( Managed Code )
E N D
EEP2006基礎教學講義 • Andy Kao
.NET的架構 VS 2005 (C#,VB,J#..) WinForm ASP.NET Base Class Library CLR (Common Language Runtime ) Windows
認識.NET • 是一個高階平台,不是個 OS • 是一個方便於程式師的開發平台 • 更強的 VM 虛擬機概念 ( Managed Code ) • 強大的資料交換機制 ( SOAP / XML ) • 完整強大的基礎元件庫 ( BCL ) • 更容易的部署及安裝 • 多平台 ( Win / Web / Mobile )
認識VS 2005 • 支持.NET 2.0 / ASP .NET 2.0 • 多語言 ( VB / C++ / C# / J# ) • 支援完整的SDLC • 內建程式分析與測量工具 • 內建測試工具 • 專案管理控制 • 親和IDE
EEP 2006的概觀 EEP S/D Module EEP 2006 VS 2005 (C#,VB,J#..) ASP.NET WinForm Base Class Library CLR (Common Language Runtime ) Web Windows
EEP2006 A/P Server 架構 Database Server EEP A/P Server 多資料庫管理 Pooling管理 Log管理系統 Method管理 平衡負載管理 Login管理 Bug管理 版本管理 ServiceManager InfoCommand InfoDataSource AutoNum Transaction UpdateComp Microsoft VS 2005 .NET 2.0
Server端元件 • ServiceManager • InfoConnection • InfoCommand • InfoDataSource • UpdateComp • AutoNumber • InfoTransaction • Loginfo
Client端元件 • InfoRefVal • InfoDataTimePicker • InfoComboBox • AutoSeq • MultiLanguage • ClientQuery • InfoDataSet • CacheDataSet • InfoBindingSource • InfoNavigator • DefaultValidate • InfoTextBox • InfoDataGridView
VS 2005 基礎設計
第一個VS 2005程式 • Solution/Project • cs/Designer.cs/resx • ToolBox/Property/Event • View Code • Say Hello的程式MessageBox.Show("hello ! EEP2006"); • Open Form的程式 • Form Form_temp = new Form2(); • Form_temp.Show();
基本指令 • Using (namespace) • 變數:Bool,int,long,float,double, • char,string,enum,struct,[] • 運算元: +,-,*,/,>,>,>=,<=,!=,== , • &&,|| • If/else/while/for/switch • Object Access
一個簡單的程式 • 將TextBox1的文字轉成ASCII碼 • listBox1.Items.Clear(); • for (int i=0;i<textBox1.TextLength;i++) • { string x = textBox1.Text; • listBox1.Items.Add(Convert.ToInt16(x[i])); • }
EEP 2006 單檔設計
EEP2006安裝 • SETUP EEP2006 • initEEP (InfoRemoteModule,Srvtools) • OPEN Solution1.sln • Export Template • EEPServer.EXE • DB Manager • Create System Table
單檔設計 DB Server A/P Server Client Database select InfoCommand dump Insert/Update/Delete Get Columns UpdateComp Binding InfoDataSet Insert/Update/Delete InfoBindingSource
單檔Server端開發 • Add Server Project • Server: DB Module define (InfoConnection, InfoCommand, UpdateComp) • Build • Package Manager
單檔Client端開發 • Add Client Project • Client: Dataset Define (InfoDataSet ,InfoBindingSource, InfoDataGridView, InfoTextBox, InfoNavigator ) • Build • EEP Manager/Menu Item
DefaultValidate控制 • Default: 公司名稱/最近訂單日 • Carryon: 預設上一筆. • 動態Default: 取得日期. • Validate: 連絡人不為空. • Validate: 地址不能都空白(Code) • Range: City設定範圍值. • AutoDisibleControl=True • CloseProtect=True
EEP 2006 一對多設計
一對多設計 DB Server A/P Server Client Database select Master InfoCommand dump Insert/Update/Delete InfoDataSource InfoDataSet UpdateComp Insert/Update/ Delete Insert/Update/Delete Binding Detail InfoCommand Master InfoBindingSource Relation UpdateComp Detail InfoBindingSource
一對多Server端開發 • Add Server Project • Server: DB Module define (InfoConnection, InfoCommand, InfoDataSource, UpdateComp) • Build • Package Manager
一對多Client端開發 • Add Client Project • Client: InfoDataSet Define (InfoDataSet ,Maser InfoBindingSource, • Detail InfoBindingSource, InfoTextBox, InfoDataGridView, InfoNavigator ) • Build • EEP Manager/Menu Item
運算式與加總 • InfoDataGridView.Columntype: InfoDataGridViewExpressionColumn, • Expression: UnitPrice*quantity • InfoDataGridView.TotalColumns • InfoDataGridView.TotalChanged事件 • if (e.ColumnName == "Amount" && • (infoNavigator1.GetCurrentState() == "Inserting" || infoNavigator1.GetCurrentState() == "Editing") • { • InfoTextBox7.Text = e.TotalValue.ToString(); • }
EEP 2006 使用Wizard
單檔Wizard • Server Package Wizard • (選擇DBAlias,Table,Columns, • KeyFields) • Client Package Wizard • (選擇RemoteName與Columns)
一對多Wizard • Server Package Wizard • (選擇DBAlias,一對多Table, Columns,KeyFields) • Client Package Wizard • (選擇RemoteName與Columns)
EEP 2006 關連設計
使用Left Join • Server端: • InfoCommand: 使用Left Join • UpdateComp: 設定ExceptJoin • Client端: • InfoTextBox/ InfoDataGridView • ReadOnly=True.
使用RefVal • 兩種連結:DataSource/SelectCommand • DataSource: 連InfoBindingSource->InfoDataSet->InfoCommand • SelectCommand: GLModule共用InfoComand (要設SelectAlias) • 設定DisplayMember, ValueMember • 使用InfoRefValBox, 設定RefVal
EEP 2006 ViewDataSet設計
ViewDataSet優化效能 DB Server A/P Server Client View InfoCommand select dump Database View InfoDataSet select Master InfoCommand Insert/Update/Delete Relations InfoDataSource View InfoDataSet InfoDataSet UpdateComp Insert/Update/Delete Insert/Update/ Delete Binding Detail InfoCommand Master InfoBindingSource Relation UpdateComp Detail InfoBindingSource
ViewDataSet • Server Module: 多貼一個InfoCommand • Add Client Project • Client: 貼一個View的InfoDataSet • & View的InfoBindingSource • & InfoBindingSource.Relations • InfoNavigator.ViewBindingSource
自動編號設定 • Server: Autonumber • MYGETDATE() • { string ret = System.DateTime.Today.ToString("yyMMdd"); • return ret; } • System Table: SysAutonum • Client: AutoSeq • ServerModify: UpdateComp,InfoDataSet • ServerModifyColumns: UpdateComp • ServerModifyGetMax: UpdateComp
EEP 2006 Transaction設計
Transaction原理 DB Server Database select A/P Server InfoCommand Insert/Delete/Update Active UpdateComp Update (inc/dec/replace) Apply Append Mode: AutoAppend Except Ignore AlwaysAppend Client InfoDataSet
變更Northwind alter table products add LastOrderedPrice money null alter table customers add LastOrderedDate datetime null alter table customers add FreightAmount money null alter table orders add OrderNo varchar(10) null create table dbo.OrderedLog (SeqID int identity (1,1) NOT NULL, OrderID int NOT NULL, ProductID int NOT NULL, UnitPrice money NOT NULL, Quantity smallint NOT NULL)
Transaction的實例 Orders DB Server A/P Server select Customers Insert/Delete/Update Master InfoCommand Inc OrderedAmout Replace LastOrderedDate Client Order Details Master UpdateComp Active select Detail InfoCommand Apply Insert/Delete/Update Products Inc UnitsOnOrder Replace LastOrderedPrice Master CDS Detail UpdateComp Apply Log Transaction OrderedLog Detail CDS
Transaction設計 • Orders Transaction : Customers • Freight Inc OrderedAmout • Replace LastOrderedDate • Order Details Transaction: Products • Quantity Inc UnitsOnOrder • UnitPrice Replace LastOrderedPrice • AlwaysAppend: OrderedLog
EEP 2006 Server Method設計
Server Method原理 DB Server A/P Server Database select ServiceManager Server Method1 …… Server Method2 …… Server Method3 …… Server Method4 ….. Update Call 同步/非同步 Client InfoCommand
Server Method設計 • 設計Server Method: • public object CallTest(object[] objParam) • {string str = objParam[0].ToString(); • string sql= "select avg(UnitPrice) as AvgPrice from [order details] Where ProductID="; • sql = sql + str; • DataSet Tmp = ExecuteSql("view", sql, true); • string retval=Tmp.Tables[0].Rows[0][‘AvgPrice’].ToString(); • Thread.Sleep(5000); • object ret; • ret = new object[] { 0, retval}; • return ret; } • 定義ServiceManager
Server Method設計 • 同步Client: • private void button1_Click(object sender, EventArgs e) • { object[] param; • param=new object[] {textBox1.Text}; • object[] backParam = CliUtils.CallMethod("STEST2", "CallTest",param); • MessageBox.Show(backParam[1].ToString()); • } • 非同步Client: • public void MyCallBack(object[] oRet) • { MessageBox.Show((string)oRet[1]); • } • object[] backParam = CliUtils.AsyncCallMethod("STEST2", "CallTest",param,MyCallBack);
EEP 2006 WEB設計
認識ASP .NET • 語言(VB/C#/J#..) • Code Behind技術 • 元件化的方式 • 好的debug環境 • Rander 的技術 • 更強資料連結(ADO .NET與XML) • 更容易的WebService