自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

LINQ表間關(guān)系查詢

開(kāi)發(fā) 后端
這里介紹LINQ表間關(guān)系查詢,包括介紹EnitityRef與EntitySet相反,用于一對(duì)多關(guān)系中的“一”方。與[Association]屬性結(jié)合使用來(lái)定義并表示一個(gè)關(guān)系。

XX有很多值得學(xué)習(xí)的地方,這里我們主要介紹LINQ表間關(guān)系查詢,包括介紹EntitySet和EntytyRef等方面。

LINQ表間關(guān)系查詢

EnitySet類型為一對(duì)多關(guān)系中的“多”方的結(jié)果提供集合。與[Association]屬性結(jié)合使用來(lái)定義并表示一個(gè)關(guān)系。OtherKey特性,指定在關(guān)聯(lián)的另一端上作為鍵值的、目標(biāo)實(shí)體類的一個(gè)或多個(gè)成員。

EnitityRef與EntitySet相反,用于一對(duì)多關(guān)系中的“一”方。與[Association]屬性結(jié)合使用來(lái)定義并表示一個(gè)關(guān)系。ThisKey表示關(guān)聯(lián)的此端上的鍵值的此實(shí)體類成員。

LINQ表間關(guān)系查詢-EntitySet

  1. //Student實(shí)體類  
  2. [Table(Name = "Student")]  
  3. public class Student  
  4. {  
  5. [Column(IsPrimaryKey = trueDbType = "int")]  
  6. public int ID;  
  7. [Column(DbType = "varchar(50)")]  
  8. public string StuName;  
  9. [Column(DbType = "bit")]  
  10. public bool Sex;  
  11. [Column(DbType = "int")]  
  12. public int Age;  
  13. private EntitySet _scores;  
  14. [Association(Storage = "_scores"OtherKey = "StudentID")]  
  15. public EntitySet Score  
  16. {  
  17. get { return this._scores; }  
  18. set { this._scores.Assign(value); }  
  19. }  
  20. }  
  21. //Scores實(shí)體類  
  22. [Table(Name = "Score")]  
  23. public class Score  
  24. {  
  25. [Column(IsPrimaryKey = trueDbType = "int")]  
  26. public int ID;  
  27. [Column(DbType = "int")]  
  28. public int StudentID;  
  29. [Column(DbType = "float")]  
  30. public float Math;  
  31. [Column(DbType = "float")]public float Chinese;  
  32. [Column(DbType = "float")]  
  33. public float English;  
  34. [Column(DbType = "Datetime")]  
  35. public DateTime Times;  
  36. }  
  37. public class TestDB : DataContext  
  38. {  
  39. public TestDB(string constr)  
  40. : base(constr)  
  41. { }  
  42. public Table Student;  
  43. public Table Scores;  
  44. }  
  45. static string constr = "server=.;database=test;uid=sa;pwd=sa;";  
  46. static void Main()  
  47. {  
  48. //調(diào)用存儲(chǔ)課程  
  49. TestDB Test = new TestDB(constr);  
  50. IQueryable s = from stu in Test.Student  
  51. select stu;  
  52. foreach (var v in s)  
  53. {  
  54. Console.WriteLine(v.StuName);  
  55. foreach (var o in v.Score)  
  56. {  
  57. Console.WriteLine(" 編號(hào):{0},學(xué)生姓名:{1},學(xué)生年齡:{2},
    語(yǔ)文成績(jī):{3},考試時(shí)間:{4}", v.ID, v.StuName, v.Age, 
    o.Chinese, o.Times.ToString("yyyy年MM月dd日"));  
  58. }  
  59. }  

表間關(guān)系查詢-EntytyRef

  1. //Student實(shí)體類  
  2. [Table(Name = "Student")]  
  3. public class Student  
  4. {  
  5. [Column(IsPrimaryKey = trueDbType = "int")]  
  6. public int ID;  
  7. [Column(DbType = "varchar(50)")]  
  8. public string StuName;  
  9. [Column(DbType = "bit")]  
  10. public bool Sex;  
  11. [Column(DbType = "int")]  
  12. public int Age;  
  13. }  
  14. //Scores實(shí)體類  
  15. [Table(Name = "Score")]  
  16. public class Score  
  17. {  
  18. [Column(IsPrimaryKey = trueDbType = "int")]  
  19. public int ID  
  20. [Column(DbType = "int")]  
  21. public int StudentID;  
  22. [Column(DbType = "float")]  
  23. public float Math;  
  24. [Column(DbType = "float")]  
  25. public float Chinese;  
  26. [Column(DbType = "float")]  
  27. public float English;  
  28. [Column(DbType = "Datetime")]  
  29. public DateTime Times;  
  30. private EntityRef _Student;  
  31. [Association(Storage = "_Student"ThisKey = "StudentID")]  
  32. public Student Student  
  33. {  
  34. get { return this._Student.Entity; }  
  35. set { this._Student.Entity = value; }  
  36. }  
  37. }  
  38. public class TestDB : DataContext  
  39. {  
  40. public TestDB(string constr)  
  41. : base(constr)  
  42. { }  
  43. public Table Student;  
  44. public Table Scores;  
  45. }  
  46. static string constr = "server=.;database=test;uid=sa;pwd=sa;";  
  47. static void Main()  
  48. {  
  49. //調(diào)用存儲(chǔ)課程  
  50. TestDB Test = new TestDB(constr);  
  51. var query = from sco in Test.Scores  
  52. select sco;  
  53. foreach (var s in query)  
  54. {  
  55. Console.WriteLine(" 編號(hào):{0},學(xué)生姓名:{1},學(xué)生年齡:{2},
    語(yǔ)文成績(jī):{3},考試時(shí)間:{4}", s.StudentID ,s.Student.StuName, 
    s.Student.Age,s.Chinese, s.Times.ToString("yyyy年MM月dd日"));  
  56. }  

【編輯推薦】

  1. LINQ to SQL查詢分析
  2. LINQ查詢架構(gòu)簡(jiǎn)單介紹
  3. LINQ to SQL映射關(guān)系概述
  4. LINQ To SQL對(duì)象模型淺析
  5. LINQ to SQL映射列描述
責(zé)任編輯:佚名 來(lái)源: IT168
相關(guān)推薦

2010-08-24 09:47:05

LINQ to SQL

2009-09-14 18:57:19

LINQ查詢

2009-09-15 15:45:00

Linq聯(lián)合查詢

2009-09-15 11:29:04

LINQ to SQL

2009-09-09 16:07:16

Linq實(shí)體關(guān)系

2009-09-16 10:38:43

LINQ查詢

2009-09-17 13:15:20

LINQ查詢

2009-09-15 10:46:04

LINQ to SQL

2009-09-16 10:08:06

LINQ查詢

2009-09-09 16:53:53

LINQ查詢語(yǔ)法

2009-09-14 10:13:02

LINQ查詢操作

2009-09-10 16:28:17

LINQ查詢

2009-09-14 10:09:26

LINQ查詢結(jié)果

2009-09-08 17:27:18

LINQ to Dat

2009-09-16 10:48:32

LINQ查詢操作

2009-09-08 09:24:50

LINQ查詢

2009-09-14 10:20:52

LINQ查詢語(yǔ)法

2009-09-10 14:47:53

Linq .NET查詢

2009-09-07 17:05:10

LINQ進(jìn)行查詢

2009-09-09 15:10:35

LINQ查詢句法
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)