亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

從零開始編寫自己的C#框架(6)——SubSonic3.0插件介紹(附源碼)

2019-11-17 01:29:31
字體:
來源:轉載
供稿:網友

從零開始編寫自己的C#框架(6)——SubSonic3.0插件介紹(附源碼

  前面幾章主要是概念性的東西為主,向初學者們介紹項目開始前的一些知識與內容,從本章開始將會進入實操階段,希望跟著本系統學習的朋友認真按說明做好每一步操作(對于代碼最好是直接照著文檔內容在你的IDE中打一次出來,而不是使用復制粘貼),這樣對你理解后面的章節會有較好的幫助,如果你對我這種書寫方式有什么建議或支持,也希望在評論中留言,謝謝你的支持。

  SubSonic3.0簡介

  SubSonic是Rob Conery用c#語言寫的一 個ORM開源框架,使用BSD軟件授權許可(The BSD 3-Clause License)。它是一個實用的快速開發框架,通過非常簡單的配置,以及附帶的T4模板,就可以幫我們生成功能強大的數據訪問層工具,讓開發人員遠離SQL語句的拼接,專注于業務邏輯的開發。

  SubSonic3.0適合短、平、快的中小型項目開發,支持MsSql、MySQL與SQLite三種數據庫,支持Linq和支持事務。對數據庫操作靈活,對生成的SQL語句會自動進行優化,雖然是ORM框架,但在性能上并沒有太大的損失。它上手容易,是一個非常棒的ORM開發框架。

  3.0版本最大的缺點是框架未開發完善,對多表關聯查詢支持的不是很好,只支持一個多表關聯條件(復雜的多表關聯只能使用存儲過程或SQL語句拼接方式來實現);條件語句對In與Not In不支持(需要在數據層重新封裝處理才行);如果使用Redis緩存的話,存儲數據時對subsonic3.0生成的實體有兼容問題,需要做一次轉換封裝后才能使用。

  不過總的來說,這些缺點都是可以克服的,在開發效率、二次開發、軟件維護上來說,優點也是非常明顯的,請大家耐心學完本系列,你就能很容易的掌握SubSonic3.0這個開發利器。

  SubSonic3.0安裝說明

  SubSonic3.0安裝練習相關附件下載

  在MsSql中新建一個數據庫SubSonicTest,并設置好登陸帳號與密碼為SubSonicTest。

  運行下載包里的“SQL語句.txt”文件里的語句,生成數據表、記錄與測試用的存儲過程。

  

  創建一個空白解決方案

  

  在解決方案中創建一個空Web應用程序項目

  

  將SubSonic文件夾復制進項目文件夾中

  

  刷新項目就可以看到隱藏的SubSonic文件夾

  

  打開Web.config,添加數據庫鏈接字串

  

  

<connectionStrings>    <!-- 連接數據庫的字符串 -->    <add name="View Code

  將Dll和SubSonic.Core復制到解決方案中

  

  添加SubSonic3.0項目(直接使用源碼項目,方便在使用時調試及修改)

  

  

  

  添加SubSonic.Core項目和Castle.Core.dll引用(大神TerryLee的博客里有Castle 開發系列文章 有興趣的朋友可以進去學習一下)

  

  

  

  將SubSonic包含進項目中

  

  如果你的數據庫名稱、帳號和密碼設置同面前要求一樣的話,T4模板將會直接運行生成相關實體類,如果設置不一樣的,請按下面要求來進行設置

  打開Settings.ttinclude配置文件

  

  

  設置好以后,選擇全部T4模板文件,運行生成代碼

  

  

  SubSonic3.0模板介紹說明

  本文只介紹附件中SubSonic文件夾模板(MsSql),不適用官方發布的模板

文件名稱說明
ActiveRecord.tt按數據表生成對應名稱的類實體(Model),以及支持lambda表達式的各種常用函數(包括增、改、查、刪、Exists等)
Context.tt 生成常用公共模版函數:Select、Insert、Avg、Count、Max、Min、Variance、StandardDeviation、Sum、Delete、GetQuery、Update等
CreateModel.tt新增模板(原SubSonic3.0沒有這個模板),主要功能是數據表生成對應名稱的類實體(Model),這是普通的類實體,不附任何多余的內容(函數),主要用于存儲到Redis緩存或做C/S接口通訊時轉Json使用。非必須項
EntityTable.tt新增模板(原SubSonic3.0沒有這個模板,里面的功能從Structs.tt模板中分離出來的),主要功能是可直接獲取數據表名稱與字段名稱,減少開發中硬編碼的存在
Settings.ttinclude模版參數配置
SQLServer.ttinclude MsSql數據庫讀取、生成的相關配置
StoredProcedures.tt生成存儲過程調用函數(本模板生成的函數調用存儲過程非常方便,詳情請關注例子)
Structs.tt生成表結構模版,提供給SubSonic插件調用

  SubSonic3.0使用例子

  點擊下載本文本例子的解決方案源碼

  之前發布過《SubSonic3.0使用例子》,當時剛開始接觸寫得有點亂,現在重新整理一下,使用上面生成的類來進行操作,可以在項目中直接運行。對于下面的例子,可以直接在解決方案中Debug運行,查看運行結果,以加深理解,當然大部分功能在正式開發中很少使用,所以簡單了解一下就可以了,只要會用Lambda,那么后面相關章節介紹時你就會使用。

  下面例子只適用于本文所附帶的模板,特此說明

using System;using System.Collections.Generic;using System.Data;using System.Linq;using System.Text;using Solution.Dataaccess.DataModel;using SubSonic.Linq.Structure;using SubSonic.Query;namespace SubSonicTest{    public partial class Test : System.Web.UI.Page    {        protected void Page_Load(object sender, EventArgs e)        {            //-------------------------------------------------------------------------------            // 新增記錄            //-------------------------------------------------------------------------------            var branch = new Branch();            branch.DeptCode = SPs.P_Branch_GetMaxBranchCode(2, 1).ExecuteScalar() + "";            branch.Name = "客服部";            branch.Comment = "客戶售后服務維護部門";            branch.ParentId = 1;            branch.Sort = 7;            branch.Depth = 2;            //AddDate這個屬性不用賦值,ORM框架生成更新語句時會自動過濾該字段,更新時將會使用數據庫中設置的默認值            //branch.AddDate = DateTime.Now;            //保存進數據庫            branch.Save();            WriteLine("記錄添加成功,新增Id為:" + branch.Id);            //-------------------------------------------------------------------------------            // 修改記錄            //-------------------------------------------------------------------------------            //從數據庫中讀出剛添加的記錄            var branchModel = Branch.SingleOrDefault(x => x.Id == branch.Id);            //也可以用這個            //var branchModel = new Branch(x => x.Id == branch.Id);            //打印讀取出來的數據            WriteLine(branchModel.ToString());            //修改名稱為“售后服務部”            branchModel.Name = "售后服務部";            //保存進數據庫            branchModel.Save();            //重新從數據庫中讀取出來并打印到輸出窗口            WriteLine((new Branch(x => x.Id == branch.Id)).ToString());            //-------------------------------------------------------------------------------            // 判斷剛剛修改的記錄是否存在            //-------------------------------------------------------------------------------            if (Branch.Exists(x => x.Id == branch.Id))            {                WriteLine("Id為" + branch.Id + "的記錄存在!");            }            else            {                WriteLine("Id為" + branch.Id + "的記錄不存在!");            }            //-------------------------------------------------------------------------------            // 刪除記錄            //-------------------------------------------------------------------------------            //刪除當前記錄            Branch.Delete(x => x.Id == branch.Id);            //也可以使用這種方法刪除            //branchModel.Delete();             Wri
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲精品成人av| 久久久精品欧美| 久久国产精品久久久久| 欧美丝袜美女中出在线| 国产精品日韩在线一区| 成人久久久久爱| 精品亚洲男同gayvideo网站| 精品久久久久久久久久久久久| 日本不卡高字幕在线2019| 国产成人精品日本亚洲专区61| 日韩欧美在线第一页| 日韩一中文字幕| 国产精品视频一区国模私拍| 91午夜理伦私人影院| 久久久国产一区二区三区| 午夜伦理精品一区| 国产丝袜一区二区三区| 国产久一一精品| 最好看的2019的中文字幕视频| 国产性色av一区二区| 国产精品男人的天堂| 日韩h在线观看| 国产美女精品视频| 亚洲热线99精品视频| 日韩精品中文字幕在线观看| 国产精品私拍pans大尺度在线| 不卡在线观看电视剧完整版| 欧美日韩国产精品专区| 欧美成人一二三| 国产精品吴梦梦| 欧美性感美女h网站在线观看免费| 欧美贵妇videos办公室| 欧美高清激情视频| 98视频在线噜噜噜国产| 久国内精品在线| 亚洲va久久久噜噜噜| 在线成人激情黄色| 日本久久久久久久久| 久久成人人人人精品欧| 午夜精品在线视频| 亚洲片国产一区一级在线观看| 国产视频自拍一区| 91社影院在线观看| 日韩成人中文字幕在线观看| 日韩欧美成人区| 亚洲一区二区三区xxx视频| 亚洲人成五月天| 午夜精品久久17c| 亚洲国内高清视频| 成人精品一区二区三区| 日韩欧美精品中文字幕| 亚洲人成在线观看| 亚洲欧洲xxxx| 亚洲另类欧美自拍| 国产欧美日韩综合精品| 国产精品久久久久久久久久小说| 亚洲精品国精品久久99热| 欧美日韩国内自拍| 97欧美精品一区二区三区| 91网站免费观看| 国产精品日本精品| 欧美专区福利在线| 日韩电影大片中文字幕| 亚洲视频在线免费观看| 国语自产精品视频在线看| 91精品免费视频| 中国china体内裑精亚洲片| 国产精品www色诱视频| 欧美成人免费在线视频| 欧美精品国产精品日韩精品| 国产精品一区二区三区免费视频| 欧美一区二粉嫩精品国产一线天| 日韩视频中文字幕| 成人有码在线视频| 中文字幕亚洲色图| 欧美激情xxxx性bbbb| 亚洲精品国产成人| 2023亚洲男人天堂| 91亚洲精品在线| 欧美激情视频一区二区| 国产一区欧美二区三区| 国产亚洲激情视频在线| 欧美激情二区三区| 亚洲精品成a人在线观看| 欧美激情区在线播放| 88xx成人精品| 在线观看欧美日韩| 91亚洲一区精品| 国产婷婷色综合av蜜臀av| 亚洲人成五月天| 全色精品综合影院| 欧美电影在线观看完整版| 久久精品夜夜夜夜夜久久| 美日韩在线视频| 日韩精品小视频| 欧美国产精品va在线观看| 国产一区二区丝袜高跟鞋图片| 中文国产成人精品久久一| 狠狠色狠狠色综合日日小说| 最近2019年好看中文字幕视频| 精品一区二区三区电影| 国产精品永久免费观看| 国产精品久久久久久久午夜| 国产精品视频一| 亚洲大胆人体av| 亚洲区免费影片| 欧美激情国产精品| 一本大道久久加勒比香蕉| 中文字幕亚洲欧美一区二区三区| 6080yy精品一区二区三区| 日韩中文有码在线视频| 亚洲精品福利在线观看| 欧美一级视频免费在线观看| 国产精品免费一区二区三区都可以| 国产不卡精品视男人的天堂| 亚洲高清一二三区| 久久天天躁狠狠躁夜夜爽蜜月| 欧美精品激情blacked18| 欧美成人免费视频| 成人午夜激情网| 宅男66日本亚洲欧美视频| www.日韩欧美| 啪一啪鲁一鲁2019在线视频| 亚洲日本成人女熟在线观看| 热久久免费国产视频| 久热精品在线视频| 国产精品无av码在线观看| 国内精品久久久久久久久| 久久久视频在线| 日韩精品久久久久| 日韩av在线资源| 国产脚交av在线一区二区| 国语自产精品视频在线看抢先版图片| 国产一区香蕉久久| 久久精品人人爽| 日韩欧美精品网址| 国产一区二中文字幕在线看| 亚洲japanese制服美女| 成人免费观看网址| 精品国产视频在线| 97婷婷大伊香蕉精品视频| 国产91在线高潮白浆在线观看| 日韩av电影免费观看高清| 国产日韩欧美自拍| 久久久电影免费观看完整版| 丝袜美腿亚洲一区二区| 日韩美女在线播放| 国内自拍欧美激情| 日韩在线国产精品| 国产精品美女免费| 中文字幕日韩欧美| 中文字幕亚洲综合久久| 在线观看欧美www| 日本精品视频在线| 欧美成人四级hd版| 亚洲欧美一区二区激情| 亚洲欧洲在线看| 亚洲精品美女久久久| 亚洲精品欧美日韩专区| 中文字幕一区日韩电影| 一区二区三区国产在线观看| 日韩专区在线观看| 欧美精品一区在线播放| 色婷婷成人综合|