System.Data.SQLite
Hex Artifact Content
Not logged in

Artifact 0eb6d94e58472a1ff0a74084397d38becdae34e2:


0000: ef bb bf 75 73 69 6e 67 20 53 79 73 74 65 6d 3b  ...using System;
0010: 0d 0a 75 73 69 6e 67 20 53 79 73 74 65 6d 2e 44  ..using System.D
0020: 69 61 67 6e 6f 73 74 69 63 73 3b 0a 75 73 69 6e  iagnostics;.usin
0030: 67 20 53 79 73 74 65 6d 2e 4c 69 6e 71 3b 0a 75  g System.Linq;.u
0040: 73 69 6e 67 20 53 79 73 74 65 6d 2e 44 61 74 61  sing System.Data
0050: 2e 4f 62 6a 65 63 74 73 3b 0d 0a 75 73 69 6e 67  .Objects;..using
0060: 20 53 79 73 74 65 6d 2e 54 65 78 74 3b 0a 0a 6e   System.Text;..n
0070: 61 6d 65 73 70 61 63 65 20 74 65 73 74 6c 69 6e  amespace testlin
0080: 71 0a 7b 0a 20 20 63 6c 61 73 73 20 50 72 6f 67  q.{.  class Prog
0090: 72 61 6d 0a 20 20 7b 0d 0a 20 20 20 20 20 20 70  ram.  {..      p
00a0: 72 69 76 61 74 65 20 73 74 61 74 69 63 20 69 6e  rivate static in
00b0: 74 20 4d 61 69 6e 28 73 74 72 69 6e 67 5b 5d 20  t Main(string[] 
00c0: 61 72 67 73 29 0d 0a 20 20 20 20 20 20 7b 0d 0a  args)..      {..
00d0: 20 20 20 20 20 20 20 20 20 20 69 66 20 28 45 6e            if (En
00e0: 76 69 72 6f 6e 6d 65 6e 74 2e 47 65 74 45 6e 76  vironment.GetEnv
00f0: 69 72 6f 6e 6d 65 6e 74 56 61 72 69 61 62 6c 65  ironmentVariable
0100: 28 22 42 52 45 41 4b 22 29 20 21 3d 20 6e 75 6c  ("BREAK") != nul
0110: 6c 29 0d 0a 20 20 20 20 20 20 20 20 20 20 7b 0d  l)..          {.
0120: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 43  .              C
0130: 6f 6e 73 6f 6c 65 2e 57 72 69 74 65 4c 69 6e 65  onsole.WriteLine
0140: 28 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  (..             
0150: 20 20 20 20 20 22 41 74 74 61 63 68 20 61 20 64       "Attach a d
0160: 65 62 75 67 67 65 72 20 74 6f 20 70 72 6f 63 65  ebugger to proce
0170: 73 73 20 7b 30 7d 20 61 6e 64 20 70 72 65 73 73  ss {0} and press
0180: 20 61 6e 79 20 6b 65 79 20 74 6f 20 63 6f 6e 74   any key to cont
0190: 69 6e 75 65 2e 22 2c 0d 0a 20 20 20 20 20 20 20  inue.",..       
01a0: 20 20 20 20 20 20 20 20 20 20 20 50 72 6f 63 65             Proce
01b0: 73 73 2e 47 65 74 43 75 72 72 65 6e 74 50 72 6f  ss.GetCurrentPro
01c0: 63 65 73 73 28 29 2e 49 64 29 3b 0d 0a 0d 0a 20  cess().Id);.... 
01d0: 20 20 20 20 20 20 20 20 20 20 20 20 20 74 72 79               try
01e0: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ..              
01f0: 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  {..             
0200: 20 20 20 20 20 43 6f 6e 73 6f 6c 65 2e 52 65 61       Console.Rea
0210: 64 4b 65 79 28 74 72 75 65 29 3b 20 2f 2a 20 74  dKey(true); /* t
0220: 68 72 6f 77 20 2a 2f 0d 0a 20 20 20 20 20 20 20  hrow */..       
0230: 20 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 20 20         }..      
0240: 20 20 20 20 20 20 20 20 63 61 74 63 68 20 28 49          catch (I
0250: 6e 76 61 6c 69 64 4f 70 65 72 61 74 69 6f 6e 45  nvalidOperationE
0260: 78 63 65 70 74 69 6f 6e 29 20 2f 2f 20 43 6f 6e  xception) // Con
0270: 73 6f 6c 65 2e 52 65 61 64 4b 65 79 0d 0a 20 20  sole.ReadKey..  
0280: 20 20 20 20 20 20 20 20 20 20 20 20 7b 0d 0a 20              {.. 
0290: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
02a0: 20 2f 2f 20 64 6f 20 6e 6f 74 68 69 6e 67 2e 0d   // do nothing..
02b0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7d  .              }
02c0: 0d 0a 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20  ....            
02d0: 20 20 44 65 62 75 67 67 65 72 2e 42 72 65 61 6b    Debugger.Break
02e0: 28 29 3b 0d 0a 20 20 20 20 20 20 20 20 20 20 7d  ();..          }
02f0: 0d 0a 0d 0a 20 20 20 20 20 20 20 20 20 20 73 74  ....          st
0300: 72 69 6e 67 20 61 72 67 20 3d 20 6e 75 6c 6c 3b  ring arg = null;
0310: 0d 0a 0d 0a 20 20 20 20 20 20 20 20 20 20 69 66  ....          if
0320: 20 28 28 61 72 67 73 20 21 3d 20 6e 75 6c 6c 29   ((args != null)
0330: 20 26 26 20 28 61 72 67 73 2e 4c 65 6e 67 74 68   && (args.Length
0340: 20 3e 20 30 29 29 0d 0a 20 20 20 20 20 20 20 20   > 0))..        
0350: 20 20 20 20 20 20 61 72 67 20 3d 20 61 72 67 73        arg = args
0360: 5b 30 5d 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20  [0];....        
0370: 20 20 69 66 20 28 61 72 67 20 3d 3d 20 6e 75 6c    if (arg == nul
0380: 6c 29 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20  l)..            
0390: 20 20 61 72 67 20 3d 20 22 22 3b 0d 0a 0d 0a 20    arg = "";.... 
03a0: 20 20 20 20 20 20 20 20 20 61 72 67 20 3d 20 61           arg = a
03b0: 72 67 2e 54 72 69 6d 28 29 2e 54 72 69 6d 53 74  rg.Trim().TrimSt
03c0: 61 72 74 28 27 2d 27 2c 20 27 2f 27 29 2e 54 6f  art('-', '/').To
03d0: 4c 6f 77 65 72 49 6e 76 61 72 69 61 6e 74 28 29  LowerInvariant()
03e0: 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20 20 20 73  ;....          s
03f0: 77 69 74 63 68 20 28 61 72 67 29 0d 0a 20 20 20  witch (arg)..   
0400: 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20         {..      
0410: 20 20 20 20 20 20 20 20 63 61 73 65 20 22 22 3a          case "":
0420: 20 2f 2f 20 53 74 72 69 6e 67 2e 45 6d 70 74 79   // String.Empty
0430: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ..              
0440: 63 61 73 65 20 22 6f 6c 64 22 3a 0d 0a 20 20 20  case "old":..   
0450: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7b                 {
0460: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ..              
0470: 20 20 20 20 20 20 20 20 72 65 74 75 72 6e 20 4f          return O
0480: 6c 64 54 65 73 74 73 28 29 3b 0d 0a 20 20 20 20  ldTests();..    
0490: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7d 0d                }.
04a0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 63  .              c
04b0: 61 73 65 20 22 73 6b 69 70 22 3a 0d 0a 20 20 20  ase "skip":..   
04c0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7b                 {
04d0: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ..              
04e0: 20 20 20 20 20 20 20 20 69 6e 74 20 70 61 67 65          int page
04f0: 53 69 7a 65 20 3d 20 30 3b 0d 0a 0d 0a 20 20 20  Size = 0;....   
0500: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0510: 20 20 20 69 66 20 28 61 72 67 73 2e 4c 65 6e 67     if (args.Leng
0520: 74 68 20 3e 20 31 29 0d 0a 20 20 20 20 20 20 20  th > 1)..       
0530: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7b                 {
0540: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ..              
0550: 20 20 20 20 20 20 20 20 20 20 20 20 61 72 67 20              arg 
0560: 3d 20 61 72 67 73 5b 31 5d 3b 0d 0a 0d 0a 20 20  = args[1];....  
0570: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0580: 20 20 20 20 20 20 20 20 69 66 20 28 61 72 67 20          if (arg 
0590: 21 3d 20 6e 75 6c 6c 29 0d 0a 20 20 20 20 20 20  != null)..      
05a0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
05b0: 20 20 20 20 20 20 20 20 70 61 67 65 53 69 7a 65          pageSize
05c0: 20 3d 20 69 6e 74 2e 50 61 72 73 65 28 61 72 67   = int.Parse(arg
05d0: 2e 54 72 69 6d 28 29 29 3b 0d 0a 20 20 20 20 20  .Trim());..     
05e0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
05f0: 20 7d 0d 0a 0d 0a 20 20 20 20 20 20 20 20 20 20   }....          
0600: 20 20 20 20 20 20 20 20 20 20 20 20 72 65 74 75              retu
0610: 72 6e 20 53 6b 69 70 54 65 73 74 28 70 61 67 65  rn SkipTest(page
0620: 53 69 7a 65 29 3b 0d 0a 20 20 20 20 20 20 20 20  Size);..        
0630: 20 20 20 20 20 20 20 20 20 20 7d 0d 0a 20 20 20            }..   
0640: 20 20 20 20 20 20 20 20 20 20 20 63 61 73 65 20             case 
0650: 22 65 6e 64 73 77 69 74 68 22 3a 0d 0a 20 20 20  "endswith":..   
0660: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7b                 {
0670: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ..              
0680: 20 20 20 20 20 20 20 20 73 74 72 69 6e 67 20 76          string v
0690: 61 6c 75 65 20 3d 20 6e 75 6c 6c 3b 0d 0a 0d 0a  alue = null;....
06a0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
06b0: 20 20 20 20 20 20 69 66 20 28 61 72 67 73 2e 4c        if (args.L
06c0: 65 6e 67 74 68 20 3e 20 31 29 0d 0a 20 20 20 20  ength > 1)..    
06d0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
06e0: 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20    {..           
06f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 76                 v
0700: 61 6c 75 65 20 3d 20 61 72 67 73 5b 31 5d 3b 0d  alue = args[1];.
0710: 0a 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  ...             
0720: 20 20 20 20 20 20 20 20 20 20 20 20 20 69 66 20               if 
0730: 28 76 61 6c 75 65 20 21 3d 20 6e 75 6c 6c 29 0d  (value != null).
0740: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
0750: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 76                 v
0760: 61 6c 75 65 20 3d 20 76 61 6c 75 65 2e 54 72 69  alue = value.Tri
0770: 6d 28 29 3b 0d 0a 20 20 20 20 20 20 20 20 20 20  m();..          
0780: 20 20 20 20 20 20 20 20 20 20 20 20 7d 0d 0a 0d              }...
0790: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
07a0: 20 20 20 20 20 20 20 72 65 74 75 72 6e 20 45 6e         return En
07b0: 64 73 57 69 74 68 54 65 73 74 28 76 61 6c 75 65  dsWithTest(value
07c0: 29 3b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20  );..            
07d0: 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 20 20 20        }..       
07e0: 20 20 20 20 20 20 20 63 61 73 65 20 22 73 74 61         case "sta
07f0: 72 74 73 77 69 74 68 22 3a 0d 0a 20 20 20 20 20  rtswith":..     
0800: 20 20 20 20 20 20 20 20 20 20 20 20 20 7b 0d 0a               {..
0810: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0820: 20 20 20 20 20 20 73 74 72 69 6e 67 20 76 61 6c        string val
0830: 75 65 20 3d 20 6e 75 6c 6c 3b 0d 0a 0d 0a 20 20  ue = null;....  
0840: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0850: 20 20 20 20 69 66 20 28 61 72 67 73 2e 4c 65 6e      if (args.Len
0860: 67 74 68 20 3e 20 31 29 0d 0a 20 20 20 20 20 20  gth > 1)..      
0870: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0880: 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  {..             
0890: 20 20 20 20 20 20 20 20 20 20 20 20 20 76 61 6c               val
08a0: 75 65 20 3d 20 61 72 67 73 5b 31 5d 3b 0d 0a 0d  ue = args[1];...
08b0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
08c0: 20 20 20 20 20 20 20 20 20 20 20 69 66 20 28 76             if (v
08d0: 61 6c 75 65 20 21 3d 20 6e 75 6c 6c 29 0d 0a 20  alue != null).. 
08e0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
08f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 76 61 6c               val
0900: 75 65 20 3d 20 76 61 6c 75 65 2e 54 72 69 6d 28  ue = value.Trim(
0910: 29 3b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20  );..            
0920: 20 20 20 20 20 20 20 20 20 20 7d 0d 0a 0d 0a 20            }.... 
0930: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0940: 20 20 20 20 20 72 65 74 75 72 6e 20 53 74 61 72       return Star
0950: 74 73 57 69 74 68 54 65 73 74 28 76 61 6c 75 65  tsWithTest(value
0960: 29 3b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20  );..            
0970: 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 20 20 20        }..       
0980: 20 20 20 20 20 20 20 64 65 66 61 75 6c 74 3a 0d         default:.
0990: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
09a0: 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20     {..          
09b0: 20 20 20 20 20 20 20 20 20 20 20 20 43 6f 6e 73              Cons
09c0: 6f 6c 65 2e 57 72 69 74 65 4c 69 6e 65 28 22 75  ole.WriteLine("u
09d0: 6e 6b 6e 6f 77 6e 20 74 65 73 74 20 5c 22 7b 30  nknown test \"{0
09e0: 7d 5c 22 22 2c 20 61 72 67 29 3b 0d 0a 20 20 20  }\"", arg);..   
09f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0a00: 20 20 20 72 65 74 75 72 6e 20 31 3b 0d 0a 20 20     return 1;..  
0a10: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0a20: 7d 0d 0a 20 20 20 20 20 20 20 20 20 20 7d 0d 0a  }..          }..
0a30: 20 20 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 20        }....     
0a40: 20 2f 2f 0d 0a 20 20 20 20 20 20 2f 2f 20 4e 4f   //..      // NO
0a50: 54 45 3a 20 55 73 65 64 20 74 6f 20 74 65 73 74  TE: Used to test
0a60: 20 74 68 65 20 66 69 78 20 66 6f 72 20 74 69 63   the fix for tic
0a70: 6b 65 74 20 5b 38 62 37 64 31 37 39 63 33 63 5d  ket [8b7d179c3c]
0a80: 2e 0d 0a 20 20 20 20 20 20 2f 2f 0d 0a 20 20 20  ...      //..   
0a90: 20 20 20 70 72 69 76 61 74 65 20 73 74 61 74 69     private stati
0aa0: 63 20 69 6e 74 20 53 6b 69 70 54 65 73 74 28 69  c int SkipTest(i
0ab0: 6e 74 20 70 61 67 65 53 69 7a 65 29 0d 0a 20 20  nt pageSize)..  
0ac0: 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 20      {..         
0ad0: 20 75 73 69 6e 67 20 28 6e 6f 72 74 68 77 69 6e   using (northwin
0ae0: 64 45 46 45 6e 74 69 74 69 65 73 20 64 62 20 3d  dEFEntities db =
0af0: 20 6e 65 77 20 6e 6f 72 74 68 77 69 6e 64 45 46   new northwindEF
0b00: 45 6e 74 69 74 69 65 73 28 29 29 0d 0a 20 20 20  Entities())..   
0b10: 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20         {..      
0b20: 20 20 20 20 20 20 20 20 62 6f 6f 6c 20 6f 6e 63          bool onc
0b30: 65 20 3d 20 66 61 6c 73 65 3b 0d 0a 20 20 20 20  e = false;..    
0b40: 20 20 20 20 20 20 20 20 20 20 69 6e 74 20 63 6f            int co
0b50: 75 6e 74 20 3d 20 64 62 2e 43 75 73 74 6f 6d 65  unt = db.Custome
0b60: 72 73 2e 43 6f 75 6e 74 28 29 3b 0d 0a 0d 0a 20  rs.Count();.... 
0b70: 20 20 20 20 20 20 20 20 20 20 20 20 20 69 6e 74               int
0b80: 20 50 61 67 65 43 6f 75 6e 74 20 3d 20 28 70 61   PageCount = (pa
0b90: 67 65 53 69 7a 65 20 21 3d 20 30 29 20 3f 0d 0a  geSize != 0) ?..
0ba0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0bb0: 20 20 28 63 6f 75 6e 74 20 2f 20 70 61 67 65 53    (count / pageS
0bc0: 69 7a 65 29 20 2b 20 28 28 63 6f 75 6e 74 20 25  ize) + ((count %
0bd0: 20 70 61 67 65 53 69 7a 65 29 20 3d 3d 20 30 20   pageSize) == 0 
0be0: 3f 20 30 20 3a 20 31 29 20 3a 20 31 3b 0d 0a 0d  ? 0 : 1) : 1;...
0bf0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 66  .              f
0c00: 6f 72 20 28 69 6e 74 20 70 61 67 65 49 6e 64 65  or (int pageInde
0c10: 78 20 3d 20 30 3b 20 70 61 67 65 49 6e 64 65 78  x = 0; pageIndex
0c20: 20 3c 20 50 61 67 65 43 6f 75 6e 74 3b 20 70 61   < PageCount; pa
0c30: 67 65 49 6e 64 65 78 2b 2b 29 0d 0a 20 20 20 20  geIndex++)..    
0c40: 20 20 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20            {..   
0c50: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 76                 v
0c60: 61 72 20 71 75 65 72 79 20 3d 20 64 62 2e 43 75  ar query = db.Cu
0c70: 73 74 6f 6d 65 72 73 2e 4f 72 64 65 72 42 79 28  stomers.OrderBy(
0c80: 70 20 3d 3e 20 70 2e 43 69 74 79 29 2e 0d 0a 20  p => p.City)... 
0c90: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0ca0: 20 20 20 20 20 53 6b 69 70 28 70 61 67 65 53 69       Skip(pageSi
0cb0: 7a 65 20 2a 20 70 61 67 65 49 6e 64 65 78 29 2e  ze * pageIndex).
0cc0: 54 61 6b 65 28 70 61 67 65 53 69 7a 65 29 3b 0d  Take(pageSize);.
0cd0: 0a 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  ...             
0ce0: 20 20 20 20 20 66 6f 72 65 61 63 68 20 28 43 75       foreach (Cu
0cf0: 73 74 6f 6d 65 72 73 20 63 75 73 74 6f 6d 65 72  stomers customer
0d00: 73 20 69 6e 20 71 75 65 72 79 29 0d 0a 20 20 20  s in query)..   
0d10: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7b                 {
0d20: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ..              
0d30: 20 20 20 20 20 20 20 20 69 66 20 28 6f 6e 63 65          if (once
0d40: 29 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  )..             
0d50: 20 20 20 20 20 20 20 20 20 20 20 20 20 43 6f 6e               Con
0d60: 73 6f 6c 65 2e 57 72 69 74 65 28 27 20 27 29 3b  sole.Write(' ');
0d70: 0d 0a 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20  ....            
0d80: 20 20 20 20 20 20 20 20 20 20 43 6f 6e 73 6f 6c            Consol
0d90: 65 2e 57 72 69 74 65 28 63 75 73 74 6f 6d 65 72  e.Write(customer
0da0: 73 2e 43 75 73 74 6f 6d 65 72 49 44 29 3b 0d 0a  s.CustomerID);..
0db0: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ..              
0dc0: 20 20 20 20 20 20 20 20 6f 6e 63 65 20 3d 20 74          once = t
0dd0: 72 75 65 3b 0d 0a 20 20 20 20 20 20 20 20 20 20  rue;..          
0de0: 20 20 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 20          }..     
0df0: 20 20 20 20 20 20 20 20 20 7d 0d 0a 20 20 20 20           }..    
0e00: 20 20 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 20        }....     
0e10: 20 20 20 20 20 72 65 74 75 72 6e 20 30 3b 0d 0a       return 0;..
0e20: 20 20 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 20        }....     
0e30: 20 2f 2f 0d 0a 20 20 20 20 20 20 2f 2f 20 4e 4f   //..      // NO
0e40: 54 45 3a 20 55 73 65 64 20 74 6f 20 74 65 73 74  TE: Used to test
0e50: 20 74 68 65 20 66 69 78 20 66 6f 72 20 74 69 63   the fix for tic
0e60: 6b 65 74 20 5b 35 39 65 64 63 31 30 31 38 62 5d  ket [59edc1018b]
0e70: 2e 0d 0a 20 20 20 20 20 20 2f 2f 0d 0a 20 20 20  ...      //..   
0e80: 20 20 20 70 72 69 76 61 74 65 20 73 74 61 74 69     private stati
0e90: 63 20 69 6e 74 20 45 6e 64 73 57 69 74 68 54 65  c int EndsWithTe
0ea0: 73 74 28 73 74 72 69 6e 67 20 76 61 6c 75 65 29  st(string value)
0eb0: 0d 0a 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20  ..      {..     
0ec0: 20 20 20 20 20 75 73 69 6e 67 20 28 6e 6f 72 74       using (nort
0ed0: 68 77 69 6e 64 45 46 45 6e 74 69 74 69 65 73 20  hwindEFEntities 
0ee0: 64 62 20 3d 20 6e 65 77 20 6e 6f 72 74 68 77 69  db = new northwi
0ef0: 6e 64 45 46 45 6e 74 69 74 69 65 73 28 29 29 0d  ndEFEntities()).
0f00: 0a 20 20 20 20 20 20 20 20 20 20 7b 0d 0a 20 20  .          {..  
0f10: 20 20 20 20 20 20 20 20 20 20 20 20 62 6f 6f 6c              bool
0f20: 20 6f 6e 63 65 20 3d 20 66 61 6c 73 65 3b 0d 0a   once = false;..
0f30: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 76 61                va
0f40: 72 20 71 75 65 72 79 20 3d 20 66 72 6f 6d 20 63  r query = from c
0f50: 20 69 6e 20 64 62 2e 43 75 73 74 6f 6d 65 72 73   in db.Customers
0f60: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ..              
0f70: 20 20 20 20 20 20 20 20 20 20 20 20 77 68 65 72              wher
0f80: 65 20 63 2e 43 69 74 79 2e 45 6e 64 73 57 69 74  e c.City.EndsWit
0f90: 68 28 76 61 6c 75 65 29 0d 0a 20 20 20 20 20 20  h(value)..      
0fa0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0fb0: 20 20 20 20 6f 72 64 65 72 62 79 20 63 2e 43 75      orderby c.Cu
0fc0: 73 74 6f 6d 65 72 49 44 0d 0a 20 20 20 20 20 20  stomerID..      
0fd0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0fe0: 20 20 20 20 73 65 6c 65 63 74 20 63 3b 0d 0a 0d      select c;...
0ff0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 66  .              f
1000: 6f 72 65 61 63 68 20 28 43 75 73 74 6f 6d 65 72  oreach (Customer
1010: 73 20 63 75 73 74 6f 6d 65 72 73 20 69 6e 20 71  s customers in q
1020: 75 65 72 79 29 0d 0a 20 20 20 20 20 20 20 20 20  uery)..         
1030: 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20       {..        
1040: 20 20 20 20 20 20 20 20 20 20 69 66 20 28 6f 6e            if (on
1050: 63 65 29 0d 0a 20 20 20 20 20 20 20 20 20 20 20  ce)..           
1060: 20 20 20 20 20 20 20 20 20 20 20 43 6f 6e 73 6f             Conso
1070: 6c 65 2e 57 72 69 74 65 28 27 20 27 29 3b 0d 0a  le.Write(' ');..
1080: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ..              
1090: 20 20 20 20 43 6f 6e 73 6f 6c 65 2e 57 72 69 74      Console.Writ
10a0: 65 28 63 75 73 74 6f 6d 65 72 73 2e 43 75 73 74  e(customers.Cust
10b0: 6f 6d 65 72 49 44 29 3b 0d 0a 0d 0a 20 20 20 20  omerID);....    
10c0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 6f 6e                on
10d0: 63 65 20 3d 20 74 72 75 65 3b 0d 0a 20 20 20 20  ce = true;..    
10e0: 20 20 20 20 20 20 20 20 20 20 7d 0d 0a 20 20 20            }..   
10f0: 20 20 20 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20         }....    
1100: 20 20 20 20 20 20 72 65 74 75 72 6e 20 30 3b 0d        return 0;.
1110: 0a 20 20 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20  .      }....    
1120: 20 20 2f 2f 0d 0a 20 20 20 20 20 20 2f 2f 20 4e    //..      // N
1130: 4f 54 45 3a 20 55 73 65 64 20 74 6f 20 76 65 72  OTE: Used to ver
1140: 69 66 79 20 74 68 65 20 62 65 68 61 76 69 6f 72  ify the behavior
1150: 20 66 72 6f 6d 20 74 69 63 6b 65 74 20 5b 30 30   from ticket [00
1160: 66 38 36 66 39 37 33 39 5d 2e 0d 0a 20 20 20 20  f86f9739]...    
1170: 20 20 2f 2f 0d 0a 20 20 20 20 20 20 70 72 69 76    //..      priv
1180: 61 74 65 20 73 74 61 74 69 63 20 69 6e 74 20 53  ate static int S
1190: 74 61 72 74 73 57 69 74 68 54 65 73 74 28 73 74  tartsWithTest(st
11a0: 72 69 6e 67 20 76 61 6c 75 65 29 0d 0a 20 20 20  ring value)..   
11b0: 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20     {..          
11c0: 75 73 69 6e 67 20 28 6e 6f 72 74 68 77 69 6e 64  using (northwind
11d0: 45 46 45 6e 74 69 74 69 65 73 20 64 62 20 3d 20  EFEntities db = 
11e0: 6e 65 77 20 6e 6f 72 74 68 77 69 6e 64 45 46 45  new northwindEFE
11f0: 6e 74 69 74 69 65 73 28 29 29 0d 0a 20 20 20 20  ntities())..    
1200: 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20        {..       
1210: 20 20 20 20 20 20 20 62 6f 6f 6c 20 6f 6e 63 65         bool once
1220: 20 3d 20 66 61 6c 73 65 3b 0d 0a 20 20 20 20 20   = false;..     
1230: 20 20 20 20 20 20 20 20 20 76 61 72 20 71 75 65           var que
1240: 72 79 20 3d 20 66 72 6f 6d 20 63 20 69 6e 20 64  ry = from c in d
1250: 62 2e 43 75 73 74 6f 6d 65 72 73 0d 0a 20 20 20  b.Customers..   
1260: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1270: 20 20 20 20 20 20 20 77 68 65 72 65 20 63 2e 43         where c.C
1280: 69 74 79 2e 53 74 61 72 74 73 57 69 74 68 28 76  ity.StartsWith(v
1290: 61 6c 75 65 29 0d 0a 20 20 20 20 20 20 20 20 20  alue)..         
12a0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
12b0: 20 6f 72 64 65 72 62 79 20 63 2e 43 75 73 74 6f   orderby c.Custo
12c0: 6d 65 72 49 44 0d 0a 20 20 20 20 20 20 20 20 20  merID..         
12d0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
12e0: 20 73 65 6c 65 63 74 20 63 3b 0d 0a 0d 0a 20 20   select c;....  
12f0: 20 20 20 20 20 20 20 20 20 20 20 20 66 6f 72 65              fore
1300: 61 63 68 20 28 43 75 73 74 6f 6d 65 72 73 20 63  ach (Customers c
1310: 75 73 74 6f 6d 65 72 73 20 69 6e 20 71 75 65 72  ustomers in quer
1320: 79 29 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20  y)..            
1330: 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20    {..           
1340: 20 20 20 20 20 20 20 69 66 20 28 6f 6e 63 65 29         if (once)
1350: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ..              
1360: 20 20 20 20 20 20 20 20 43 6f 6e 73 6f 6c 65 2e          Console.
1370: 57 72 69 74 65 28 27 20 27 29 3b 0d 0a 0d 0a 20  Write(' ');.... 
1380: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1390: 20 43 6f 6e 73 6f 6c 65 2e 57 72 69 74 65 28 63   Console.Write(c
13a0: 75 73 74 6f 6d 65 72 73 2e 43 75 73 74 6f 6d 65  ustomers.Custome
13b0: 72 49 44 29 3b 0d 0a 0d 0a 20 20 20 20 20 20 20  rID);....       
13c0: 20 20 20 20 20 20 20 20 20 20 20 6f 6e 63 65 20             once 
13d0: 3d 20 74 72 75 65 3b 0d 0a 20 20 20 20 20 20 20  = true;..       
13e0: 20 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 20 20         }..      
13f0: 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 20 20 20      }....       
1400: 20 20 20 72 65 74 75 72 6e 20 30 3b 0d 0a 20 20     return 0;..  
1410: 20 20 20 20 7d 0d 0a 0a 20 20 20 20 70 72 69 76      }...    priv
1420: 61 74 65 20 73 74 61 74 69 63 20 69 6e 74 20 4f  ate static int O
1430: 6c 64 54 65 73 74 73 28 29 0a 20 20 20 20 7b 0d  ldTests().    {.
1440: 0a 20 20 20 20 20 20 75 73 69 6e 67 20 28 6e 6f  .      using (no
1450: 72 74 68 77 69 6e 64 45 46 45 6e 74 69 74 69 65  rthwindEFEntitie
1460: 73 20 64 62 20 3d 20 6e 65 77 20 6e 6f 72 74 68  s db = new north
1470: 77 69 6e 64 45 46 45 6e 74 69 74 69 65 73 28 29  windEFEntities()
1480: 29 0a 20 20 20 20 20 20 7b 0a 20 20 20 20 20 20  ).      {.      
1490: 20 20 7b 0a 20 20 20 20 20 20 20 20 20 20 73 74    {.          st
14a0: 72 69 6e 67 20 65 6e 74 69 74 79 53 51 4c 20 3d  ring entitySQL =
14b0: 20 22 53 45 4c 45 43 54 20 56 41 4c 55 45 20 6f   "SELECT VALUE o
14c0: 20 46 52 4f 4d 20 4f 72 64 65 72 73 20 41 53 20   FROM Orders AS 
14d0: 6f 20 57 48 45 52 45 20 53 51 4c 69 74 65 2e 44  o WHERE SQLite.D
14e0: 61 74 65 50 61 72 74 28 27 79 79 79 79 27 2c 20  atePart('yyyy', 
14f0: 6f 2e 4f 72 64 65 72 44 61 74 65 29 20 3d 20 31  o.OrderDate) = 1
1500: 39 39 37 3b 22 3b 0a 20 20 20 20 20 20 20 20 20  997;";.         
1510: 20 4f 62 6a 65 63 74 51 75 65 72 79 3c 4f 72 64   ObjectQuery<Ord
1520: 65 72 73 3e 20 71 75 65 72 79 20 3d 20 64 62 2e  ers> query = db.
1530: 43 72 65 61 74 65 51 75 65 72 79 3c 4f 72 64 65  CreateQuery<Orde
1540: 72 73 3e 28 65 6e 74 69 74 79 53 51 4c 29 3b 0a  rs>(entitySQL);.
1550: 0a 20 20 20 20 20 20 20 20 20 20 66 6f 72 65 61  .          forea
1560: 63 68 20 28 4f 72 64 65 72 73 20 6f 20 69 6e 20  ch (Orders o in 
1570: 71 75 65 72 79 29 0a 20 20 20 20 20 20 20 20 20  query).         
1580: 20 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20 43   {.            C
1590: 6f 6e 73 6f 6c 65 2e 57 72 69 74 65 4c 69 6e 65  onsole.WriteLine
15a0: 28 6f 2e 53 68 69 70 50 6f 73 74 61 6c 43 6f 64  (o.ShipPostalCod
15b0: 65 29 3b 0a 20 20 20 20 20 20 20 20 20 20 7d 0a  e);.          }.
15c0: 20 20 20 20 20 20 20 20 7d 0a 0a 20 20 20 20 20          }..     
15d0: 20 20 20 7b 0a 20 20 20 20 20 20 20 20 20 20 76     {.          v
15e0: 61 72 20 71 75 65 72 79 20 3d 20 66 72 6f 6d 20  ar query = from 
15f0: 63 20 69 6e 20 64 62 2e 43 75 73 74 6f 6d 65 72  c in db.Customer
1600: 73 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  s.              
1610: 20 20 20 20 20 20 20 20 77 68 65 72 65 20 63 2e          where c.
1620: 43 69 74 79 20 3d 3d 20 22 4c 6f 6e 64 6f 6e 22  City == "London"
1630: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
1640: 20 20 20 20 20 20 20 6f 72 64 65 72 62 79 20 63         orderby c
1650: 2e 43 6f 6d 70 61 6e 79 4e 61 6d 65 0a 20 20 20  .CompanyName.   
1660: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1670: 20 20 20 73 65 6c 65 63 74 20 63 3b 0a 0a 20 20     select c;..  
1680: 20 20 20 20 20 20 20 20 69 6e 74 20 63 63 20 3d          int cc =
1690: 20 71 75 65 72 79 2e 43 6f 75 6e 74 28 29 3b 0a   query.Count();.
16a0: 0a 20 20 20 20 20 20 20 20 20 20 66 6f 72 65 61  .          forea
16b0: 63 68 20 28 43 75 73 74 6f 6d 65 72 73 20 63 20  ch (Customers c 
16c0: 69 6e 20 71 75 65 72 79 29 0a 20 20 20 20 20 20  in query).      
16d0: 20 20 20 20 7b 0a 20 20 20 20 20 20 20 20 20 20      {.          
16e0: 20 20 43 6f 6e 73 6f 6c 65 2e 57 72 69 74 65 4c    Console.WriteL
16f0: 69 6e 65 28 63 2e 43 6f 6d 70 61 6e 79 4e 61 6d  ine(c.CompanyNam
1700: 65 29 3b 0a 20 20 20 20 20 20 20 20 20 20 7d 0a  e);.          }.
1710: 20 20 20 20 20 20 20 20 7d 0a 0a 20 20 20 20 20          }..     
1720: 20 20 20 7b 0a 20 20 20 20 20 20 20 20 20 20 73     {.          s
1730: 74 72 69 6e 67 20 73 63 69 74 79 20 3d 20 22 4c  tring scity = "L
1740: 6f 6e 64 6f 6e 22 3b 0a 20 20 20 20 20 20 20 20  ondon";.        
1750: 20 20 43 75 73 74 6f 6d 65 72 73 20 63 20 3d 20    Customers c = 
1760: 64 62 2e 43 75 73 74 6f 6d 65 72 73 2e 46 69 72  db.Customers.Fir
1770: 73 74 4f 72 44 65 66 61 75 6c 74 28 63 64 20 3d  stOrDefault(cd =
1780: 3e 20 63 64 2e 43 69 74 79 20 3d 3d 20 73 63 69  > cd.City == sci
1790: 74 79 29 3b 0a 20 20 20 20 20 20 20 20 20 20 43  ty);.          C
17a0: 6f 6e 73 6f 6c 65 2e 57 72 69 74 65 4c 69 6e 65  onsole.WriteLine
17b0: 28 63 2e 43 6f 6d 70 61 6e 79 4e 61 6d 65 29 3b  (c.CompanyName);
17c0: 0a 20 20 20 20 20 20 20 20 7d 0a 0a 20 20 20 20  .        }..    
17d0: 20 20 20 20 7b 0a 20 20 20 20 20 20 20 20 20 20      {.          
17e0: 44 61 74 65 54 69 6d 65 20 64 74 20 3d 20 6e 65  DateTime dt = ne
17f0: 77 20 44 61 74 65 54 69 6d 65 28 31 39 39 37 2c  w DateTime(1997,
1800: 20 31 2c 20 31 29 3b 0a 20 20 20 20 20 20 20 20   1, 1);.        
1810: 20 20 76 61 72 20 71 75 65 72 79 20 3d 20 66 72    var query = fr
1820: 6f 6d 20 6f 72 64 65 72 20 69 6e 20 64 62 2e 4f  om order in db.O
1830: 72 64 65 72 73 0a 20 20 20 20 20 20 20 20 20 20  rders.          
1840: 20 20 20 20 20 20 20 20 20 20 20 20 77 68 65 72              wher
1850: 65 20 6f 72 64 65 72 2e 4f 72 64 65 72 44 61 74  e order.OrderDat
1860: 65 20 3c 20 64 74 0a 20 20 20 20 20 20 20 20 20  e < dt.         
1870: 20 20 20 20 20 20 20 20 20 20 20 20 20 73 65 6c               sel
1880: 65 63 74 20 6f 72 64 65 72 3b 0a 0a 20 20 20 20  ect order;..    
1890: 20 20 20 20 20 20 66 6f 72 65 61 63 68 20 28 4f        foreach (O
18a0: 72 64 65 72 73 20 6f 20 69 6e 20 71 75 65 72 79  rders o in query
18b0: 29 0a 20 20 20 20 20 20 20 20 20 20 7b 0a 20 20  ).          {.  
18c0: 20 20 20 20 20 20 20 20 20 20 43 6f 6e 73 6f 6c            Consol
18d0: 65 2e 57 72 69 74 65 4c 69 6e 65 28 6f 2e 4f 72  e.WriteLine(o.Or
18e0: 64 65 72 44 61 74 65 2e 54 6f 53 74 72 69 6e 67  derDate.ToString
18f0: 28 29 29 3b 0a 20 20 20 20 20 20 20 20 20 20 7d  ());.          }
1900: 0a 20 20 20 20 20 20 20 20 7d 0a 0a 20 20 20 20  .        }..    
1910: 20 20 20 20 7b 0a 20 20 20 20 20 20 20 20 20 20      {.          
1920: 43 61 74 65 67 6f 72 69 65 73 20 63 20 3d 20 6e  Categories c = n
1930: 65 77 20 43 61 74 65 67 6f 72 69 65 73 28 29 3b  ew Categories();
1940: 0a 20 20 20 20 20 20 20 20 20 20 63 2e 43 61 74  .          c.Cat
1950: 65 67 6f 72 79 4e 61 6d 65 20 3d 20 22 54 65 73  egoryName = "Tes
1960: 74 20 43 61 74 65 67 6f 72 79 22 3b 0a 20 20 20  t Category";.   
1970: 20 20 20 20 20 20 20 63 2e 44 65 73 63 72 69 70         c.Descrip
1980: 74 69 6f 6e 20 3d 20 22 4d 79 20 44 65 73 63 72  tion = "My Descr
1990: 69 70 74 69 6f 6e 22 3b 0a 20 20 20 20 20 20 20  iption";.       
19a0: 20 20 20 64 62 2e 41 64 64 54 6f 43 61 74 65 67     db.AddToCateg
19b0: 6f 72 69 65 73 28 63 29 3b 0a 20 20 20 20 20 20  ories(c);.      
19c0: 20 20 20 20 64 62 2e 53 61 76 65 43 68 61 6e 67      db.SaveChang
19d0: 65 73 28 29 3b 0a 0a 20 20 20 20 20 20 20 20 20  es();..         
19e0: 20 43 6f 6e 73 6f 6c 65 2e 57 72 69 74 65 4c 69   Console.WriteLi
19f0: 6e 65 28 63 2e 43 61 74 65 67 6f 72 79 49 44 29  ne(c.CategoryID)
1a00: 3b 0a 0a 20 20 20 20 20 20 20 20 20 20 63 2e 44  ;..          c.D
1a10: 65 73 63 72 69 70 74 69 6f 6e 20 3d 20 22 4d 79  escription = "My
1a20: 20 6d 6f 64 69 66 69 65 64 20 64 65 73 63 72 69   modified descri
1a30: 70 74 69 6f 6e 22 3b 0a 20 20 20 20 20 20 20 20  ption";.        
1a40: 20 20 64 62 2e 53 61 76 65 43 68 61 6e 67 65 73    db.SaveChanges
1a50: 28 29 3b 0a 0a 20 20 20 20 20 20 20 20 20 20 64  ();..          d
1a60: 62 2e 44 65 6c 65 74 65 4f 62 6a 65 63 74 28 63  b.DeleteObject(c
1a70: 29 3b 0a 20 20 20 20 20 20 20 20 20 20 64 62 2e  );.          db.
1a80: 53 61 76 65 43 68 61 6e 67 65 73 28 29 3b 0a 20  SaveChanges();. 
1a90: 20 20 20 20 20 20 20 7d 0a 0a 20 20 20 20 20 20         }..      
1aa0: 20 20 7b 0a 20 20 20 20 20 20 20 20 20 20 43 75    {.          Cu
1ab0: 73 74 6f 6d 65 72 73 20 63 75 73 74 20 3d 20 6e  stomers cust = n
1ac0: 65 77 20 43 75 73 74 6f 6d 65 72 73 28 29 3b 0a  ew Customers();.
1ad0: 20 20 20 20 20 20 20 20 20 20 63 75 73 74 2e 43            cust.C
1ae0: 75 73 74 6f 6d 65 72 49 44 20 3d 20 22 4d 54 4d  ustomerID = "MTM
1af0: 54 4d 22 3b 0a 20 20 20 20 20 20 20 20 20 20 63  TM";.          c
1b00: 75 73 74 2e 43 6f 6e 74 61 63 74 4e 61 6d 65 20  ust.ContactName 
1b10: 3d 20 22 4d 79 20 4e 61 6d 65 22 3b 0a 20 20 20  = "My Name";.   
1b20: 20 20 20 20 20 20 20 63 75 73 74 2e 43 6f 6d 70         cust.Comp
1b30: 61 6e 79 4e 61 6d 65 20 3d 20 22 53 51 4c 69 74  anyName = "SQLit
1b40: 65 20 43 6f 6d 70 61 6e 79 22 3b 0a 20 20 20 20  e Company";.    
1b50: 20 20 20 20 20 20 63 75 73 74 2e 43 6f 75 6e 74        cust.Count
1b60: 72 79 20 3d 20 22 4e 65 74 68 65 72 6c 61 6e 64  ry = "Netherland
1b70: 73 22 3b 0a 20 20 20 20 20 20 20 20 20 20 63 75  s";.          cu
1b80: 73 74 2e 43 69 74 79 20 3d 20 22 41 6d 73 74 65  st.City = "Amste
1b90: 72 64 61 6d 22 3b 0a 20 20 20 20 20 20 20 20 20  rdam";.         
1ba0: 20 63 75 73 74 2e 50 68 6f 6e 65 20 3d 20 22 30   cust.Phone = "0
1bb0: 31 32 33 34 35 36 37 37 22 3b 0a 20 20 20 20 20  12345677";.     
1bc0: 20 20 20 20 20 64 62 2e 41 64 64 54 6f 43 75 73       db.AddToCus
1bd0: 74 6f 6d 65 72 73 28 63 75 73 74 29 3b 0a 20 20  tomers(cust);.  
1be0: 20 20 20 20 20 20 20 20 64 62 2e 53 61 76 65 43          db.SaveC
1bf0: 68 61 6e 67 65 73 28 29 3b 0a 0a 20 20 20 20 20  hanges();..     
1c00: 20 20 20 20 20 64 62 2e 44 65 6c 65 74 65 4f 62       db.DeleteOb
1c10: 6a 65 63 74 28 63 75 73 74 29 3b 0a 20 20 20 20  ject(cust);.    
1c20: 20 20 20 20 20 20 64 62 2e 53 61 76 65 43 68 61        db.SaveCha
1c30: 6e 67 65 73 28 29 3b 0a 20 20 20 20 20 20 20 20  nges();.        
1c40: 7d 0a 0a 20 20 20 20 20 20 20 20 7b 0a 20 20 20  }..        {.   
1c50: 20 20 20 20 20 20 20 76 61 72 20 71 75 65 72 79         var query
1c60: 20 3d 20 64 62 2e 43 75 73 74 6f 6d 65 72 73 2e   = db.Customers.
1c70: 57 68 65 72 65 28 63 75 73 74 20 3d 3e 20 63 75  Where(cust => cu
1c80: 73 74 2e 43 6f 75 6e 74 72 79 20 3d 3d 20 22 44  st.Country == "D
1c90: 65 6e 6d 61 72 6b 22 29 0a 20 20 20 20 20 20 20  enmark").       
1ca0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1cb0: 20 20 20 2e 53 65 6c 65 63 74 4d 61 6e 79 28 63     .SelectMany(c
1cc0: 75 73 74 20 3d 3e 20 63 75 73 74 2e 4f 72 64 65  ust => cust.Orde
1cd0: 72 73 2e 57 68 65 72 65 28 6f 20 3d 3e 20 6f 2e  rs.Where(o => o.
1ce0: 46 72 65 69 67 68 74 20 3e 20 35 29 29 3b 0a 0a  Freight > 5));..
1cf0: 20 20 20 20 20 20 20 20 20 20 66 6f 72 65 61 63            foreac
1d00: 68 20 28 4f 72 64 65 72 73 20 63 20 69 6e 20 71  h (Orders c in q
1d10: 75 65 72 79 29 0a 20 20 20 20 20 20 20 20 20 20  uery).          
1d20: 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20 43 6f  {.            Co
1d30: 6e 73 6f 6c 65 2e 57 72 69 74 65 4c 69 6e 65 28  nsole.WriteLine(
1d40: 63 2e 46 72 65 69 67 68 74 29 3b 0a 20 20 20 20  c.Freight);.    
1d50: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20        }.        
1d60: 7d 0a 0a 20 20 20 20 20 20 20 20 7b 0a 20 20 20  }..        {.   
1d70: 20 20 20 20 20 20 20 76 61 72 20 71 75 65 72 79         var query
1d80: 20 3d 20 66 72 6f 6d 20 63 20 69 6e 20 64 62 2e   = from c in db.
1d90: 43 75 73 74 6f 6d 65 72 73 0a 20 20 20 20 20 20  Customers.      
1da0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1db0: 77 68 65 72 65 20 63 2e 4f 72 64 65 72 73 2e 41  where c.Orders.A
1dc0: 6e 79 28 6f 20 3d 3e 20 6f 2e 4f 72 64 65 72 44  ny(o => o.OrderD
1dd0: 61 74 65 2e 48 61 73 56 61 6c 75 65 20 3d 3d 20  ate.HasValue == 
1de0: 74 72 75 65 20 26 26 20 6f 2e 4f 72 64 65 72 44  true && o.OrderD
1df0: 61 74 65 2e 56 61 6c 75 65 2e 59 65 61 72 20 3d  ate.Value.Year =
1e00: 3d 20 31 39 39 37 29 0a 20 20 20 20 20 20 20 20  = 1997).        
1e10: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 73 65                se
1e20: 6c 65 63 74 20 63 3b 0a 0a 20 20 20 20 20 20 20  lect c;..       
1e30: 20 20 20 66 6f 72 65 61 63 68 20 28 43 75 73 74     foreach (Cust
1e40: 6f 6d 65 72 73 20 63 20 69 6e 20 71 75 65 72 79  omers c in query
1e50: 29 0a 20 20 20 20 20 20 20 20 20 20 7b 0a 20 20  ).          {.  
1e60: 20 20 20 20 20 20 20 20 20 20 43 6f 6e 73 6f 6c            Consol
1e70: 65 2e 57 72 69 74 65 4c 69 6e 65 28 63 2e 43 6f  e.WriteLine(c.Co
1e80: 6d 70 61 6e 79 4e 61 6d 65 29 3b 0a 20 20 20 20  mpanyName);.    
1e90: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20        }.        
1ea0: 7d 0a 0a 20 20 20 20 20 20 20 20 7b 0a 20 20 20  }..        {.   
1eb0: 20 20 20 20 20 20 20 73 74 72 69 6e 67 20 65 6e         string en
1ec0: 74 69 74 79 53 51 4c 20 3d 20 22 53 45 4c 45 43  titySQL = "SELEC
1ed0: 54 20 56 41 4c 55 45 20 6f 20 46 52 4f 4d 20 4f  T VALUE o FROM O
1ee0: 72 64 65 72 73 20 41 53 20 6f 20 57 48 45 52 45  rders AS o WHERE
1ef0: 20 6f 2e 43 75 73 74 6f 6d 65 72 73 2e 43 6f 75   o.Customers.Cou
1f00: 6e 74 72 79 20 3c 3e 20 27 55 4b 27 20 41 4e 44  ntry <> 'UK' AND
1f10: 20 6f 2e 43 75 73 74 6f 6d 65 72 73 2e 43 6f 75   o.Customers.Cou
1f20: 6e 74 72 79 20 3c 3e 20 27 4d 65 78 69 63 6f 27  ntry <> 'Mexico'
1f30: 20 41 4e 44 20 59 65 61 72 28 6f 2e 4f 72 64 65   AND Year(o.Orde
1f40: 72 44 61 74 65 29 20 3d 20 31 39 39 37 3b 22 3b  rDate) = 1997;";
1f50: 0a 20 20 20 20 20 20 20 20 20 20 4f 62 6a 65 63  .          Objec
1f60: 74 51 75 65 72 79 3c 4f 72 64 65 72 73 3e 20 71  tQuery<Orders> q
1f70: 75 65 72 79 20 3d 20 64 62 2e 43 72 65 61 74 65  uery = db.Create
1f80: 51 75 65 72 79 3c 4f 72 64 65 72 73 3e 28 65 6e  Query<Orders>(en
1f90: 74 69 74 79 53 51 4c 29 3b 0a 0a 20 20 20 20 20  titySQL);..     
1fa0: 20 20 20 20 20 66 6f 72 65 61 63 68 20 28 4f 72       foreach (Or
1fb0: 64 65 72 73 20 6f 20 69 6e 20 71 75 65 72 79 29  ders o in query)
1fc0: 0a 20 20 20 20 20 20 20 20 20 20 7b 0a 20 20 20  .          {.   
1fd0: 20 20 20 20 20 20 20 20 20 43 6f 6e 73 6f 6c 65           Console
1fe0: 2e 57 72 69 74 65 4c 69 6e 65 28 6f 2e 53 68 69  .WriteLine(o.Shi
1ff0: 70 50 6f 73 74 61 6c 43 6f 64 65 29 3b 0a 20 20  pPostalCode);.  
2000: 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20          }.      
2010: 20 20 7d 0a 0a 20 20 20 20 20 20 20 20 7b 0a 20    }..        {. 
2020: 20 20 20 20 20 20 20 20 20 73 74 72 69 6e 67 20           string 
2030: 65 6e 74 69 74 79 53 51 4c 20 3d 20 22 53 45 4c  entitySQL = "SEL
2040: 45 43 54 20 56 41 4c 55 45 20 6f 20 46 52 4f 4d  ECT VALUE o FROM
2050: 20 4f 72 64 65 72 73 20 41 53 20 6f 20 57 48 45   Orders AS o WHE
2060: 52 45 20 4e 65 77 47 75 69 64 28 29 20 3c 3e 20  RE NewGuid() <> 
2070: 4e 65 77 47 75 69 64 28 29 3b 22 3b 0a 20 20 20  NewGuid();";.   
2080: 20 20 20 20 20 20 20 4f 62 6a 65 63 74 51 75 65         ObjectQue
2090: 72 79 3c 4f 72 64 65 72 73 3e 20 71 75 65 72 79  ry<Orders> query
20a0: 20 3d 20 64 62 2e 43 72 65 61 74 65 51 75 65 72   = db.CreateQuer
20b0: 79 3c 4f 72 64 65 72 73 3e 28 65 6e 74 69 74 79  y<Orders>(entity
20c0: 53 51 4c 29 3b 0a 0a 20 20 20 20 20 20 20 20 20  SQL);..         
20d0: 20 66 6f 72 65 61 63 68 20 28 4f 72 64 65 72 73   foreach (Orders
20e0: 20 6f 20 69 6e 20 71 75 65 72 79 29 0a 20 20 20   o in query).   
20f0: 20 20 20 20 20 20 20 7b 0a 20 20 20 20 20 20 20         {.       
2100: 20 20 20 20 20 43 6f 6e 73 6f 6c 65 2e 57 72 69       Console.Wri
2110: 74 65 4c 69 6e 65 28 6f 2e 53 68 69 70 50 6f 73  teLine(o.ShipPos
2120: 74 61 6c 43 6f 64 65 29 3b 0a 20 20 20 20 20 20  talCode);.      
2130: 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20 7d 0a      }.        }.
2140: 0a 20 20 20 20 20 20 20 20 2f 2f 20 54 68 69 73  .        // This
2150: 20 71 75 65 72 79 20 72 65 71 75 69 72 65 73 20   query requires 
2160: 53 51 4c 69 74 65 20 33 2e 36 2e 32 20 74 6f 20  SQLite 3.6.2 to 
2170: 66 75 6e 63 74 69 6f 6e 20 63 6f 72 72 65 63 74  function correct
2180: 6c 79 0a 20 20 20 20 20 20 20 20 7b 0a 20 20 20  ly.        {.   
2190: 20 20 20 20 20 20 20 76 61 72 20 71 75 65 72 79         var query
21a0: 20 3d 20 66 72 6f 6d 20 70 20 69 6e 20 64 62 2e   = from p in db.
21b0: 50 72 6f 64 75 63 74 73 0a 20 20 20 20 20 20 20  Products.       
21c0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 77                 w
21d0: 68 65 72 65 20 70 2e 4f 72 64 65 72 44 65 74 61  here p.OrderDeta
21e0: 69 6c 73 2e 43 6f 75 6e 74 28 6f 64 20 3d 3e 20  ils.Count(od => 
21f0: 6f 64 2e 4f 72 64 65 72 73 2e 43 75 73 74 6f 6d  od.Orders.Custom
2200: 65 72 73 2e 43 6f 75 6e 74 72 79 20 3d 3d 20 70  ers.Country == p
2210: 2e 53 75 70 70 6c 69 65 72 73 2e 43 6f 75 6e 74  .Suppliers.Count
2220: 72 79 29 20 3e 20 32 0a 20 20 20 20 20 20 20 20  ry) > 2.        
2230: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 73 65                se
2240: 6c 65 63 74 20 70 3b 0a 0a 20 20 20 20 20 20 20  lect p;..       
2250: 20 20 20 66 6f 72 65 61 63 68 20 28 50 72 6f 64     foreach (Prod
2260: 75 63 74 73 20 70 20 69 6e 20 71 75 65 72 79 29  ucts p in query)
2270: 0a 20 20 20 20 20 20 20 20 20 20 7b 0a 20 20 20  .          {.   
2280: 20 20 20 20 20 20 20 20 20 43 6f 6e 73 6f 6c 65           Console
2290: 2e 57 72 69 74 65 4c 69 6e 65 28 70 2e 50 72 6f  .WriteLine(p.Pro
22a0: 64 75 63 74 4e 61 6d 65 29 3b 0a 20 20 20 20 20  ductName);.     
22b0: 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20 7d       }.        }
22c0: 0a 20 20 20 20 20 20 7d 0a 0a 20 20 20 20 20 20  .      }..      
22d0: 2f 2f 0a 20 20 20 20 20 20 2f 2f 20 4e 4f 54 45  //.      // NOTE
22e0: 3a 20 28 4a 4a 4d 29 20 52 65 6d 6f 76 65 64 20  : (JJM) Removed 
22f0: 6f 6e 20 32 30 31 31 2f 30 37 2f 30 36 2c 20 6d  on 2011/07/06, m
2300: 61 6b 65 73 20 69 74 20 68 61 72 64 65 72 20 74  akes it harder t
2310: 6f 20 72 75 6e 20 74 68 69 73 20 45 58 45 20 76  o run this EXE v
2320: 69 61 0a 20 20 20 20 20 20 2f 2f 20 20 20 20 20  ia.      //     
2330: 20 20 74 68 65 20 6e 65 77 20 75 6e 69 74 20 74    the new unit t
2340: 65 73 74 20 73 75 69 74 65 2e 0a 20 20 20 20 20  est suite..     
2350: 20 2f 2f 0a 20 20 20 20 20 20 2f 2f 20 43 6f 6e   //.      // Con
2360: 73 6f 6c 65 2e 52 65 61 64 4b 65 79 28 29 3b 0d  sole.ReadKey();.
2370: 0a 0d 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20  ...      return 
2380: 30 3b 0a 20 20 20 20 7d 0a 20 20 7d 0a 7d 0a     0;.    }.  }.}.