擴展實體類的使用

来源:http://www.cnblogs.com/zhangzongle/archive/2016/03/29/5334042.html
-Advertisement-
Play Games

需求: 上圖中,如果我們想用實體類來實現的話,明顯實現不了 原因很簡單,要顯示的數據包含的三張表(Student,Subject,Result)中的數據 我們無法單純的用某個實體類來解決,這時我們就可以擴展實體類來解決這個問題 我們可添加ResultBusiness類繼承Result實體類 這樣我們 ...


 

需求:

上圖中,如果我們想用實體類來實現的話,明顯實現不了

原因很簡單,要顯示的數據包含的三張表(Student,Subject,Result)中的數據

我們無法單純的用某個實體類來解決,這時我們就可以擴展實體類來解決這個問題

我們可添加ResultBusiness類繼承Result實體類

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace MySchool.Model
{
    //拓展類  繼承Result實體類
   public class ResultBusiness:Result
    {
       //多定義兩個屬性(達到目的)
       //學生姓名
       public string StudentName { get; set; }
       //科目名
       public string SubjectName { get; set; }
    }
}

這樣我們就可以使用ResultBusiness類來實現目的

方法:

public List<ResultBusiness> ReviewStudentResult2(int subjectId, string name)
      {
          List<ResultBusiness> list = new List<ResultBusiness>();
          // List<Result> list = new List<Result>();
          //創建SQl
          StringBuilder sb = new StringBuilder();
          sb.Append("select * from Result,Student,Subject where Result.StudentNo=Student.studentNo and Subject.SubjectId=Result.SubjectId ");
          if (subjectId != -1)
          {
              sb.Append("and Result.SubjectId=@SubjectId ");
          }
          if (!string.IsNullOrEmpty(name))
          {

              sb.Append("and Student.StudentName like +  '%'+@Studentname+'%'");
          }
          SqlParameter[] para =
          {
              new SqlParameter("@SubjectId",subjectId),
              new SqlParameter("@Studentname",name)
          };
          SqlConnection con = new SqlConnection(Constr);
          SqlCommand cmd = new SqlCommand(sb.ToString(), con);
          cmd.Parameters.AddRange(para);
          con.Open();
          SqlDataReader dr = cmd.ExecuteReader();

          while (dr.Read())
          {

              ResultBusiness result = new ResultBusiness();
              result.StudentName = dr["StudentName"].ToString();
              result.SubjectName = dr["SubjectName"].ToString();
              result.StudentNo = Convert.ToInt32(dr["StudentNo"].ToString());
              result.StudentResult = Convert.ToInt32(dr["StudentResult"].ToString());
              result.SubjectId = Convert.ToInt32(dr["SubjectId"].ToString());
              result.ExamDate = Convert.ToDateTime(dr["ExamDate"].ToString());
              list.Add(result);
          }


          con.Close();
          dr.Close();
          return list;
      }

調用:

 public void Three()
        {
            string Name = txtName.Text;
            int grade = Convert.ToInt32(cboGrade.SelectedValue);
            List<ResultBusiness> list = resultbll.ReviewStudentResult2(grade, Name);
            dgvResult.DataSource = list;
        }

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 本課程針對零基礎的學生,或者學習編程很久,但是從來沒有動手作出一個東西的學生。 尚學堂老師精心設計項目開發流程,讓你在60分鐘內,從安裝java開發環境,使用eclipse開發環境,一直到開發出一個 撞球小游戲。 讓你驀然發現,學習編程是件多麼有意思的事情。 教程下載地址:http://www.bj ...
  • 上一節的代碼是spring-boot的入門程式,也是官方文檔上的一個程式。這一節會引入spring-boot官方文檔推薦的方式來開發代碼,並引入我們在spring開發中service層等的調用。 1、代碼結構如下 2、pom.xml 1 <?xml version="1.0" encoding="U ...
  • 1:資料庫語句: create database LandDB; use LandDB; create table T_BL_CANTON_CODE ( CTN_CODE int primary key, CTN_NAME varchar(60) not null, GOV_NAME varchar ...
  • void CXXXXDialog::OnLButtonDown(UINT nFlags, CPoint point) { PostMessage(WM_NCLBUTTONDOWN, HTCAPTION, MAKELPARAM(point.x, point.y)); } 要記得添加消息映射,不然這個代 ...
  • struct Node{ int n; Node* pNext; } void Reverse(Node* n, Node* pre, Node* p) { if(n->pNext!=NULL) { Reverse(n->pNext, n, p); } else if(n->pNext==NULL) ...
  • https://raw.githubusercontent.com/Leo G/DevopsWiki/master/README.md 總結的太好了,直接把md文件貼過來好了!慢慢學習!分享給大家,覺得好就也去 "他github" 點個贊吧! DevopsWiki A wiki of Guides, ...
  • 回到目錄 web api越來越火,因為它的跨平臺,因為它的簡單,因為它支持xml,json等流行的數據協議,我們在開發基於面向服務的API時,有個問題一直在困擾著我們,那就是數據的安全,請求的安全,一般所說的安全也無非就是請求的防篡改和請求的防復用,例如,你向API發一個查詢用戶賬戶的請求,在這個過 ...
  • Atitit.嵌入式web 伺服器 java android最佳實踐 1. Android4.4.21 2. 自己的webserver1 3. CyberHTTP for Java cybergarage6 1. Android4.4.2 First使用jetty9,三說jdk編譯級別非常高的... ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...