Artifact
352e157d08f9a5804604f33861b1505ce9630a42:
- File
testlinq/Program.cs
— part of check-in
[1fc7a1a94c]
at
2011-09-23 07:20:48
on branch LinqDateTime
— Experimental changes for better DateTime handling in the LINQ assembly (incomplete, do not use yet).
(user:
mistachkin
size: 16822)
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 0d 0a g System.Linq;..
0040: 75 73 69 6e 67 20 53 79 73 74 65 6d 2e 44 61 74 using System.Dat
0050: 61 2e 45 6e 74 69 74 79 43 6c 69 65 6e 74 3b 0a a.EntityClient;.
0060: 75 73 69 6e 67 20 53 79 73 74 65 6d 2e 44 61 74 using System.Dat
0070: 61 2e 4f 62 6a 65 63 74 73 3b 0d 0a 75 73 69 6e a.Objects;..usin
0080: 67 20 53 79 73 74 65 6d 2e 44 61 74 61 2e 53 51 g System.Data.SQ
0090: 4c 69 74 65 3b 0d 0a 75 73 69 6e 67 20 53 79 73 Lite;..using Sys
00a0: 74 65 6d 2e 54 65 78 74 3b 0a 75 73 69 6e 67 20 tem.Text;.using
00b0: 53 79 73 74 65 6d 2e 54 72 61 6e 73 61 63 74 69 System.Transacti
00c0: 6f 6e 73 3b 0d 0a 0a 6e 61 6d 65 73 70 61 63 65 ons;...namespace
00d0: 20 74 65 73 74 6c 69 6e 71 0a 7b 0a 20 20 63 6c testlinq.{. cl
00e0: 61 73 73 20 50 72 6f 67 72 61 6d 0a 20 20 7b 0d ass Program. {.
00f0: 0a 20 20 20 20 20 20 70 72 69 76 61 74 65 20 73 . private s
0100: 74 61 74 69 63 20 69 6e 74 20 4d 61 69 6e 28 73 tatic int Main(s
0110: 74 72 69 6e 67 5b 5d 20 61 72 67 73 29 0d 0a 20 tring[] args)..
0120: 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 {..
0130: 20 20 69 66 20 28 45 6e 76 69 72 6f 6e 6d 65 6e if (Environmen
0140: 74 2e 47 65 74 45 6e 76 69 72 6f 6e 6d 65 6e 74 t.GetEnvironment
0150: 56 61 72 69 61 62 6c 65 28 22 42 52 45 41 4b 22 Variable("BREAK"
0160: 29 20 21 3d 20 6e 75 6c 6c 29 0d 0a 20 20 20 20 ) != null)..
0170: 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 {..
0180: 20 20 20 20 20 20 20 43 6f 6e 73 6f 6c 65 2e 57 Console.W
0190: 72 69 74 65 4c 69 6e 65 28 0d 0a 20 20 20 20 20 riteLine(..
01a0: 20 20 20 20 20 20 20 20 20 20 20 20 20 22 41 74 "At
01b0: 74 61 63 68 20 61 20 64 65 62 75 67 67 65 72 20 tach a debugger
01c0: 74 6f 20 70 72 6f 63 65 73 73 20 7b 30 7d 20 61 to process {0} a
01d0: 6e 64 20 70 72 65 73 73 20 61 6e 79 20 6b 65 79 nd press any key
01e0: 20 74 6f 20 63 6f 6e 74 69 6e 75 65 2e 22 2c 0d to continue.",.
01f0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 .
0200: 20 20 20 50 72 6f 63 65 73 73 2e 47 65 74 43 75 Process.GetCu
0210: 72 72 65 6e 74 50 72 6f 63 65 73 73 28 29 2e 49 rrentProcess().I
0220: 64 29 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20 20 d);....
0230: 20 20 20 20 20 74 72 79 0d 0a 20 20 20 20 20 20 try..
0240: 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 {..
0250: 20 20 20 20 20 20 20 20 20 20 20 20 20 43 6f 6e Con
0260: 73 6f 6c 65 2e 52 65 61 64 4b 65 79 28 74 72 75 sole.ReadKey(tru
0270: 65 29 3b 20 2f 2a 20 74 68 72 6f 77 20 2a 2f 0d e); /* throw */.
0280: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7d . }
0290: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 ..
02a0: 63 61 74 63 68 20 28 49 6e 76 61 6c 69 64 4f 70 catch (InvalidOp
02b0: 65 72 61 74 69 6f 6e 45 78 63 65 70 74 69 6f 6e erationException
02c0: 29 20 2f 2f 20 43 6f 6e 73 6f 6c 65 2e 52 65 61 ) // Console.Rea
02d0: 64 4b 65 79 0d 0a 20 20 20 20 20 20 20 20 20 20 dKey..
02e0: 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 {..
02f0: 20 20 20 20 20 20 20 20 20 2f 2f 20 64 6f 20 6e // do n
0300: 6f 74 68 69 6e 67 2e 0d 0a 20 20 20 20 20 20 20 othing...
0310: 20 20 20 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 }....
0320: 20 20 20 20 20 20 20 20 20 20 44 65 62 75 67 67 Debugg
0330: 65 72 2e 42 72 65 61 6b 28 29 3b 0d 0a 20 20 20 er.Break();..
0340: 20 20 20 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 }....
0350: 20 20 20 20 20 20 73 74 72 69 6e 67 20 61 72 67 string arg
0360: 20 3d 20 6e 75 6c 6c 3b 0d 0a 0d 0a 20 20 20 20 = null;....
0370: 20 20 20 20 20 20 69 66 20 28 28 61 72 67 73 20 if ((args
0380: 21 3d 20 6e 75 6c 6c 29 20 26 26 20 28 61 72 67 != null) && (arg
0390: 73 2e 4c 65 6e 67 74 68 20 3e 20 30 29 29 0d 0a s.Length > 0))..
03a0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 61 72 ar
03b0: 67 20 3d 20 61 72 67 73 5b 30 5d 3b 0d 0a 0d 0a g = args[0];....
03c0: 20 20 20 20 20 20 20 20 20 20 69 66 20 28 61 72 if (ar
03d0: 67 20 3d 3d 20 6e 75 6c 6c 29 0d 0a 20 20 20 20 g == null)..
03e0: 20 20 20 20 20 20 20 20 20 20 61 72 67 20 3d 20 arg =
03f0: 22 22 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20 20 "";....
0400: 20 61 72 67 20 3d 20 61 72 67 2e 54 72 69 6d 28 arg = arg.Trim(
0410: 29 2e 54 72 69 6d 53 74 61 72 74 28 27 2d 27 2c ).TrimStart('-',
0420: 20 27 2f 27 29 2e 54 6f 4c 6f 77 65 72 49 6e 76 '/').ToLowerInv
0430: 61 72 69 61 6e 74 28 29 3b 0d 0a 0d 0a 20 20 20 ariant();....
0440: 20 20 20 20 20 20 20 73 77 69 74 63 68 20 28 61 switch (a
0450: 72 67 29 0d 0a 20 20 20 20 20 20 20 20 20 20 7b rg).. {
0460: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 ..
0470: 63 61 73 65 20 22 22 3a 20 2f 2f 20 53 74 72 69 case "": // Stri
0480: 6e 67 2e 45 6d 70 74 79 0d 0a 20 20 20 20 20 20 ng.Empty..
0490: 20 20 20 20 20 20 20 20 63 61 73 65 20 22 6f 6c case "ol
04a0: 64 22 3a 0d 0a 20 20 20 20 20 20 20 20 20 20 20 d":..
04b0: 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 {..
04c0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
04d0: 72 65 74 75 72 6e 20 4f 6c 64 54 65 73 74 73 28 return OldTests(
04e0: 29 3b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 );..
04f0: 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 20 20 20 }..
0500: 20 20 20 20 20 20 20 63 61 73 65 20 22 73 6b 69 case "ski
0510: 70 22 3a 0d 0a 20 20 20 20 20 20 20 20 20 20 20 p":..
0520: 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 {..
0530: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
0540: 69 6e 74 20 70 61 67 65 53 69 7a 65 20 3d 20 30 int pageSize = 0
0550: 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20 20 20 20 ;....
0560: 20 20 20 20 20 20 20 20 20 20 20 69 66 20 28 28 if ((
0570: 61 72 67 73 2e 4c 65 6e 67 74 68 20 3e 20 31 29 args.Length > 1)
0580: 20 26 26 20 21 53 74 72 69 6e 67 2e 49 73 4e 75 && !String.IsNu
0590: 6c 6c 4f 72 45 6d 70 74 79 28 61 72 67 73 5b 31 llOrEmpty(args[1
05a0: 5d 29 29 0d 0a 20 20 20 20 20 20 20 20 20 20 20 ]))..
05b0: 20 20 20 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 {..
05c0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
05d0: 20 20 20 20 20 20 20 20 61 72 67 20 3d 20 61 72 arg = ar
05e0: 67 73 5b 31 5d 3b 0d 0a 0d 0a 20 20 20 20 20 20 gs[1];....
05f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
0600: 20 20 20 20 69 66 20 28 61 72 67 20 21 3d 20 6e if (arg != n
0610: 75 6c 6c 29 0d 0a 20 20 20 20 20 20 20 20 20 20 ull)..
0620: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
0630: 20 20 20 20 70 61 67 65 53 69 7a 65 20 3d 20 69 pageSize = i
0640: 6e 74 2e 50 61 72 73 65 28 61 72 67 2e 54 72 69 nt.Parse(arg.Tri
0650: 6d 28 29 29 3b 0d 0a 20 20 20 20 20 20 20 20 20 m());..
0660: 20 20 20 20 20 20 20 20 20 20 20 20 20 7d 0d 0a }..
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 72 65 74 75 72 6e 20 53 return S
0690: 6b 69 70 54 65 73 74 28 70 61 67 65 53 69 7a 65 kipTest(pageSize
06a0: 29 3b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 );..
06b0: 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 20 20 20 }..
06c0: 20 20 20 20 20 20 20 63 61 73 65 20 22 65 6e 64 case "end
06d0: 73 77 69 74 68 22 3a 0d 0a 20 20 20 20 20 20 20 swith":..
06e0: 20 20 20 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 {..
06f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
0700: 20 20 20 20 73 74 72 69 6e 67 20 76 61 6c 75 65 string value
0710: 20 3d 20 6e 75 6c 6c 3b 0d 0a 0d 0a 20 20 20 20 = null;....
0720: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
0730: 20 20 69 66 20 28 61 72 67 73 2e 4c 65 6e 67 74 if (args.Lengt
0740: 68 20 3e 20 31 29 0d 0a 20 20 20 20 20 20 20 20 h > 1)..
0750: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7b 0d {.
0760: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 .
0770: 20 20 20 20 20 20 20 20 20 20 20 76 61 6c 75 65 value
0780: 20 3d 20 61 72 67 73 5b 31 5d 3b 0d 0a 0d 0a 20 = args[1];....
0790: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
07a0: 20 20 20 20 20 20 20 20 20 69 66 20 28 76 61 6c if (val
07b0: 75 65 20 21 3d 20 6e 75 6c 6c 29 0d 0a 20 20 20 ue != null)..
07c0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
07d0: 20 20 20 20 20 20 20 20 20 20 20 76 61 6c 75 65 value
07e0: 20 3d 20 76 61 6c 75 65 2e 54 72 69 6d 28 29 3b = value.Trim();
07f0: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 ..
0800: 20 20 20 20 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 }....
0810: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
0820: 20 20 20 72 65 74 75 72 6e 20 45 6e 64 73 57 69 return EndsWi
0830: 74 68 54 65 73 74 28 76 61 6c 75 65 29 3b 0d 0a thTest(value);..
0840: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
0850: 20 20 7d 0d 0a 20 20 20 20 20 20 20 20 20 20 20 }..
0860: 20 20 20 63 61 73 65 20 22 73 74 61 72 74 73 77 case "startsw
0870: 69 74 68 22 3a 0d 0a 20 20 20 20 20 20 20 20 20 ith":..
0880: 20 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 {..
0890: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
08a0: 20 20 73 74 72 69 6e 67 20 76 61 6c 75 65 20 3d string value =
08b0: 20 6e 75 6c 6c 3b 0d 0a 0d 0a 20 20 20 20 20 20 null;....
08c0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
08d0: 69 66 20 28 61 72 67 73 2e 4c 65 6e 67 74 68 20 if (args.Length
08e0: 3e 20 31 29 0d 0a 20 20 20 20 20 20 20 20 20 20 > 1)..
08f0: 20 20 20 20 20 20 20 20 20 20 20 20 7b 0d 0a 20 {..
0900: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
0910: 20 20 20 20 20 20 20 20 20 76 61 6c 75 65 20 3d value =
0920: 20 61 72 67 73 5b 31 5d 3b 0d 0a 0d 0a 20 20 20 args[1];....
0930: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
0940: 20 20 20 20 20 20 20 69 66 20 28 76 61 6c 75 65 if (value
0950: 20 21 3d 20 6e 75 6c 6c 29 0d 0a 20 20 20 20 20 != null)..
0960: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
0970: 20 20 20 20 20 20 20 20 20 76 61 6c 75 65 20 3d value =
0980: 20 76 61 6c 75 65 2e 54 72 69 6d 28 29 3b 0d 0a value.Trim();..
0990: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
09a0: 20 20 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 20 }....
09b0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
09c0: 20 72 65 74 75 72 6e 20 53 74 61 72 74 73 57 69 return StartsWi
09d0: 74 68 54 65 73 74 28 76 61 6c 75 65 29 3b 0d 0a thTest(value);..
09e0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
09f0: 20 20 7d 0d 0a 20 20 20 20 20 20 20 20 20 20 20 }..
0a00: 20 20 20 63 61 73 65 20 22 65 66 74 72 61 6e 73 case "eftrans
0a10: 61 63 74 69 6f 6e 22 3a 0d 0a 20 20 20 20 20 20 action":..
0a20: 20 20 20 20 20 20 20 20 20 20 20 20 7b 0d 0a 20 {..
0a30: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
0a40: 20 20 20 20 20 62 6f 6f 6c 20 76 61 6c 75 65 20 bool value
0a50: 3d 20 66 61 6c 73 65 3b 0d 0a 0d 0a 20 20 20 20 = false;....
0a60: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
0a70: 20 20 69 66 20 28 28 61 72 67 73 2e 4c 65 6e 67 if ((args.Leng
0a80: 74 68 20 3e 20 31 29 20 26 26 20 21 53 74 72 69 th > 1) && !Stri
0a90: 6e 67 2e 49 73 4e 75 6c 6c 4f 72 45 6d 70 74 79 ng.IsNullOrEmpty
0aa0: 28 61 72 67 73 5b 31 5d 29 29 0d 0a 20 20 20 20 (args[1]))..
0ab0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
0ac0: 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 {..
0ad0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 69 i
0ae0: 66 20 28 21 62 6f 6f 6c 2e 54 72 79 50 61 72 73 f (!bool.TryPars
0af0: 65 28 61 72 67 73 5b 31 5d 2c 20 6f 75 74 20 76 e(args[1], out v
0b00: 61 6c 75 65 29 29 0d 0a 20 20 20 20 20 20 20 20 alue))..
0b10: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
0b20: 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 {..
0b30: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
0b40: 20 20 20 43 6f 6e 73 6f 6c 65 2e 57 72 69 74 65 Console.Write
0b50: 4c 69 6e 65 28 0d 0a 20 20 20 20 20 20 20 20 20 Line(..
0b60: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
0b70: 20 20 20 20 20 20 20 20 20 22 63 61 6e 6e 6f 74 "cannot
0b80: 20 70 61 72 73 65 20 5c 22 7b 30 7d 5c 22 20 61 parse \"{0}\" a
0b90: 73 20 62 6f 6f 6c 65 61 6e 22 2c 0d 0a 20 20 20 s boolean",..
0ba0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
0bb0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 61 a
0bc0: 72 67 73 5b 31 5d 29 3b 0d 0a 0d 0a 20 20 20 20 rgs[1]);....
0bd0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
0be0: 20 20 20 20 20 20 20 20 20 20 72 65 74 75 72 6e return
0bf0: 20 31 3b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 1;..
0c00: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7d }
0c10: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 ..
0c20: 20 20 20 20 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 }....
0c30: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
0c40: 20 20 20 72 65 74 75 72 6e 20 45 46 54 72 61 6e return EFTran
0c50: 73 61 63 74 69 6f 6e 54 65 73 74 28 76 61 6c 75 sactionTest(valu
0c60: 65 29 3b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 e);..
0c70: 20 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 20 20 }..
0c80: 20 20 20 20 20 20 20 20 63 61 73 65 20 22 64 61 case "da
0c90: 74 65 74 69 6d 65 22 3a 0d 0a 20 20 20 20 20 20 tetime":..
0ca0: 20 20 20 20 20 20 20 20 20 20 20 20 7b 0d 0a 20 {..
0cb0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
0cc0: 20 20 20 20 20 53 51 4c 69 74 65 44 61 74 65 46 SQLiteDateF
0cd0: 6f 72 6d 61 74 73 20 64 61 74 65 54 69 6d 65 46 ormats dateTimeF
0ce0: 6f 72 6d 61 74 20 3d 20 53 51 4c 69 74 65 44 61 ormat = SQLiteDa
0cf0: 74 65 46 6f 72 6d 61 74 73 2e 44 65 66 61 75 6c teFormats.Defaul
0d00: 74 3b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 t;..
0d10: 20 20 20 20 20 20 20 20 20 20 73 74 72 69 6e 67 string
0d20: 20 71 75 65 72 79 53 74 72 69 6e 67 20 3d 20 6e queryString = n
0d30: 75 6c 6c 3b 0d 0a 20 20 20 20 20 20 20 20 20 20 ull;..
0d40: 20 20 20 20 20 20 20 20 20 20 20 20 44 61 74 65 Date
0d50: 54 69 6d 65 3f 20 64 61 74 65 54 69 6d 65 20 3d Time? dateTime =
0d60: 20 6e 75 6c 6c 3b 0d 0a 0d 0a 20 20 20 20 20 20 null;....
0d70: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
0d80: 69 66 20 28 28 61 72 67 73 2e 4c 65 6e 67 74 68 if ((args.Length
0d90: 20 3e 20 31 29 20 26 26 20 21 53 74 72 69 6e 67 > 1) && !String
0da0: 2e 49 73 4e 75 6c 6c 4f 72 45 6d 70 74 79 28 61 .IsNullOrEmpty(a
0db0: 72 67 73 5b 31 5d 29 29 0d 0a 20 20 20 20 20 20 rgs[1]))..
0dc0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
0dd0: 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 {..
0de0: 20 20 20 20 20 20 20 20 20 20 20 20 20 74 72 79 try
0df0: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 ..
0e00: 20 20 20 20 20 20 20 20 20 20 20 20 7b 0d 0a 20 {..
0e10: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
0e20: 20 20 20 20 20 20 20 20 20 20 20 20 20 64 61 74 dat
0e30: 65 54 69 6d 65 46 6f 72 6d 61 74 20 3d 20 28 53 eTimeFormat = (S
0e40: 51 4c 69 74 65 44 61 74 65 46 6f 72 6d 61 74 73 QLiteDateFormats
0e50: 29 45 6e 75 6d 2e 50 61 72 73 65 28 0d 0a 20 20 )Enum.Parse(..
0e60: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
0e70: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
0e80: 74 79 70 65 6f 66 28 53 51 4c 69 74 65 44 61 74 typeof(SQLiteDat
0e90: 65 46 6f 72 6d 61 74 73 29 2c 20 61 72 67 73 5b eFormats), args[
0ea0: 31 5d 2c 20 74 72 75 65 29 3b 0d 0a 20 20 20 20 1], true);..
0eb0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
0ec0: 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 20 20 20 }..
0ed0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
0ee0: 20 20 20 63 61 74 63 68 0d 0a 20 20 20 20 20 20 catch..
0ef0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
0f00: 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 {..
0f10: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
0f20: 20 20 20 20 20 43 6f 6e 73 6f 6c 65 2e 57 72 69 Console.Wri
0f30: 74 65 4c 69 6e 65 28 0d 0a 20 20 20 20 20 20 20 teLine(..
0f40: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
0f50: 20 20 20 20 20 20 20 20 20 20 20 22 63 61 6e 6e "cann
0f60: 6f 74 20 70 61 72 73 65 20 5c 22 7b 30 7d 5c 22 ot parse \"{0}\"
0f70: 20 61 73 20 61 20 64 61 74 65 2f 74 69 6d 65 20 as a date/time
0f80: 66 6f 72 6d 61 74 22 2c 0d 0a 20 20 20 20 20 20 format",..
0f90: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
0fa0: 20 20 20 20 20 20 20 20 20 20 20 20 61 72 67 73 args
0fb0: 5b 31 5d 29 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 [1]);....
0fc0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
0fd0: 20 20 20 20 20 20 20 72 65 74 75 72 6e 20 31 3b return 1;
0fe0: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 ..
0ff0: 20 20 20 20 20 20 20 20 20 20 20 20 7d 0d 0a 20 }..
1000: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
1010: 20 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 20 20 }....
1020: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
1030: 69 66 20 28 61 72 67 73 2e 4c 65 6e 67 74 68 20 if (args.Length
1040: 3e 20 32 29 0d 0a 20 20 20 20 20 20 20 20 20 20 > 2)..
1050: 20 20 20 20 20 20 20 20 20 20 20 20 7b 0d 0a 20 {..
1060: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
1070: 20 20 20 20 20 20 20 20 20 71 75 65 72 79 53 74 querySt
1080: 72 69 6e 67 20 3d 20 61 72 67 73 5b 32 5d 3b 0d ring = args[2];.
1090: 0a 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 ...
10a0: 20 20 20 20 20 20 20 20 20 20 20 20 20 69 66 20 if
10b0: 28 71 75 65 72 79 53 74 72 69 6e 67 20 21 3d 20 (queryString !=
10c0: 6e 75 6c 6c 29 0d 0a 20 20 20 20 20 20 20 20 20 null)..
10d0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
10e0: 20 20 20 20 20 71 75 65 72 79 53 74 72 69 6e 67 queryString
10f0: 20 3d 20 71 75 65 72 79 53 74 72 69 6e 67 2e 54 = queryString.T
1100: 72 69 6d 28 29 3b 0d 0a 20 20 20 20 20 20 20 20 rim();..
1110: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7d 0d }.
1120: 0a 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 ...
1130: 20 20 20 20 20 20 20 20 20 69 66 20 28 28 61 72 if ((ar
1140: 67 73 2e 4c 65 6e 67 74 68 20 3e 20 33 29 20 26 gs.Length > 3) &
1150: 26 20 21 53 74 72 69 6e 67 2e 49 73 4e 75 6c 6c & !String.IsNull
1160: 4f 72 45 6d 70 74 79 28 61 72 67 73 5b 33 5d 29 OrEmpty(args[3])
1170: 29 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 )..
1180: 20 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 {..
1190: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
11a0: 20 20 20 20 20 20 44 61 74 65 54 69 6d 65 20 64 DateTime d
11b0: 61 74 65 54 69 6d 65 56 61 6c 75 65 3b 0d 0a 0d ateTimeValue;...
11c0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 .
11d0: 20 20 20 20 20 20 20 20 20 20 20 69 66 20 28 44 if (D
11e0: 61 74 65 54 69 6d 65 2e 54 72 79 50 61 72 73 65 ateTime.TryParse
11f0: 28 61 72 67 73 5b 33 5d 2c 20 6f 75 74 20 64 61 (args[3], out da
1200: 74 65 54 69 6d 65 56 61 6c 75 65 29 29 0d 0a 20 teTimeValue))..
1210: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
1220: 20 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 {..
1230: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
1240: 20 20 20 20 20 20 20 20 20 20 64 61 74 65 54 69 dateTi
1250: 6d 65 20 3d 20 44 61 74 65 54 69 6d 65 2e 53 70 me = DateTime.Sp
1260: 65 63 69 66 79 4b 69 6e 64 28 0d 0a 20 20 20 20 ecifyKind(..
1270: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
1280: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 64 61 da
1290: 74 65 54 69 6d 65 56 61 6c 75 65 2c 20 44 61 74 teTimeValue, Dat
12a0: 65 54 69 6d 65 4b 69 6e 64 2e 55 74 63 29 3b 0d eTimeKind.Utc);.
12b0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 .
12c0: 20 20 20 20 20 20 20 20 20 20 20 7d 0d 0a 20 20 }..
12d0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
12e0: 20 20 20 20 20 20 20 20 65 6c 73 65 0d 0a 20 20 else..
12f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
1300: 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 {..
1310: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
1320: 20 20 20 20 20 20 20 20 20 43 6f 6e 73 6f 6c 65 Console
1330: 2e 57 72 69 74 65 4c 69 6e 65 28 0d 0a 20 20 20 .WriteLine(..
1340: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
1350: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 22 "
1360: 63 61 6e 6e 6f 74 20 70 61 72 73 65 20 5c 22 7b cannot parse \"{
1370: 30 7d 5c 22 20 61 73 20 61 20 64 61 74 65 2f 74 0}\" as a date/t
1380: 69 6d 65 22 2c 0d 0a 20 20 20 20 20 20 20 20 20 ime",..
1390: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
13a0: 20 20 20 20 20 20 20 20 20 61 72 67 73 5b 33 5d args[3]
13b0: 29 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20 20 20 );....
13c0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
13d0: 20 20 20 20 72 65 74 75 72 6e 20 31 3b 0d 0a 20 return 1;..
13e0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
13f0: 20 20 20 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 }..
1400: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
1410: 20 20 7d 0d 0a 0d 0a 20 20 20 20 20 20 20 20 20 }....
1420: 20 20 20 20 20 20 20 20 20 20 20 20 20 72 65 74 ret
1430: 75 72 6e 20 44 61 74 65 54 69 6d 65 54 65 73 74 urn DateTimeTest
1440: 28 64 61 74 65 54 69 6d 65 46 6f 72 6d 61 74 2c (dateTimeFormat,
1450: 20 71 75 65 72 79 53 74 72 69 6e 67 2c 20 64 61 queryString, da
1460: 74 65 54 69 6d 65 29 3b 0d 0a 20 20 20 20 20 20 teTime);..
1470: 20 20 20 20 20 20 20 20 20 20 20 20 7d 0d 0a 20 }..
1480: 20 20 20 20 20 20 20 20 20 20 20 20 20 64 65 66 def
1490: 61 75 6c 74 3a 0d 0a 20 20 20 20 20 20 20 20 20 ault:..
14a0: 20 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 {..
14b0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
14c0: 20 20 43 6f 6e 73 6f 6c 65 2e 57 72 69 74 65 4c Console.WriteL
14d0: 69 6e 65 28 22 75 6e 6b 6e 6f 77 6e 20 74 65 73 ine("unknown tes
14e0: 74 20 5c 22 7b 30 7d 5c 22 22 2c 20 61 72 67 29 t \"{0}\"", arg)
14f0: 3b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 ;..
1500: 20 20 20 20 20 20 20 20 20 72 65 74 75 72 6e 20 return
1510: 31 3b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 1;..
1520: 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 20 20 20 }..
1530: 20 20 20 7d 0d 0a 20 20 20 20 20 20 7d 0d 0a 0d }.. }...
1540: 0a 20 20 20 20 20 20 2f 2f 0d 0a 20 20 20 20 20 . //..
1550: 20 2f 2f 20 4e 4f 54 45 3a 20 55 73 65 64 20 74 // NOTE: Used t
1560: 6f 20 74 65 73 74 20 74 68 65 20 66 69 78 20 66 o test the fix f
1570: 6f 72 20 74 69 63 6b 65 74 20 5b 38 62 37 64 31 or ticket [8b7d1
1580: 37 39 63 33 63 5d 2e 0d 0a 20 20 20 20 20 20 2f 79c3c]... /
1590: 2f 0d 0a 20 20 20 20 20 20 70 72 69 76 61 74 65 /.. private
15a0: 20 73 74 61 74 69 63 20 69 6e 74 20 53 6b 69 70 static int Skip
15b0: 54 65 73 74 28 69 6e 74 20 70 61 67 65 53 69 7a Test(int pageSiz
15c0: 65 29 0d 0a 20 20 20 20 20 20 7b 0d 0a 20 20 20 e).. {..
15d0: 20 20 20 20 20 20 20 75 73 69 6e 67 20 28 6e 6f using (no
15e0: 72 74 68 77 69 6e 64 45 46 45 6e 74 69 74 69 65 rthwindEFEntitie
15f0: 73 20 64 62 20 3d 20 6e 65 77 20 6e 6f 72 74 68 s db = new north
1600: 77 69 6e 64 45 46 45 6e 74 69 74 69 65 73 28 29 windEFEntities()
1610: 29 0d 0a 20 20 20 20 20 20 20 20 20 20 7b 0d 0a ).. {..
1620: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 62 6f bo
1630: 6f 6c 20 6f 6e 63 65 20 3d 20 66 61 6c 73 65 3b ol once = false;
1640: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 ..
1650: 69 6e 74 20 63 6f 75 6e 74 20 3d 20 64 62 2e 43 int count = db.C
1660: 75 73 74 6f 6d 65 72 73 2e 43 6f 75 6e 74 28 29 ustomers.Count()
1670: 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20 20 20 20 ;....
1680: 20 20 20 69 6e 74 20 50 61 67 65 43 6f 75 6e 74 int PageCount
1690: 20 3d 20 28 70 61 67 65 53 69 7a 65 20 21 3d 20 = (pageSize !=
16a0: 30 29 20 3f 0d 0a 20 20 20 20 20 20 20 20 20 20 0) ?..
16b0: 20 20 20 20 20 20 20 20 28 63 6f 75 6e 74 20 2f (count /
16c0: 20 70 61 67 65 53 69 7a 65 29 20 2b 20 28 28 63 pageSize) + ((c
16d0: 6f 75 6e 74 20 25 20 70 61 67 65 53 69 7a 65 29 ount % pageSize)
16e0: 20 3d 3d 20 30 20 3f 20 30 20 3a 20 31 29 20 3a == 0 ? 0 : 1) :
16f0: 20 31 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20 20 1;....
1700: 20 20 20 20 20 66 6f 72 20 28 69 6e 74 20 70 61 for (int pa
1710: 67 65 49 6e 64 65 78 20 3d 20 30 3b 20 70 61 67 geIndex = 0; pag
1720: 65 49 6e 64 65 78 20 3c 20 50 61 67 65 43 6f 75 eIndex < PageCou
1730: 6e 74 3b 20 70 61 67 65 49 6e 64 65 78 2b 2b 29 nt; pageIndex++)
1740: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 ..
1750: 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 {..
1760: 20 20 20 20 20 76 61 72 20 71 75 65 72 79 20 3d var query =
1770: 20 64 62 2e 43 75 73 74 6f 6d 65 72 73 2e 4f 72 db.Customers.Or
1780: 64 65 72 42 79 28 70 20 3d 3e 20 70 2e 43 69 74 derBy(p => p.Cit
1790: 79 29 2e 0d 0a 20 20 20 20 20 20 20 20 20 20 20 y)...
17a0: 20 20 20 20 20 20 20 20 20 20 20 53 6b 69 70 28 Skip(
17b0: 70 61 67 65 53 69 7a 65 20 2a 20 70 61 67 65 49 pageSize * pageI
17c0: 6e 64 65 78 29 2e 54 61 6b 65 28 70 61 67 65 53 ndex).Take(pageS
17d0: 69 7a 65 29 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 ize);....
17e0: 20 20 20 20 20 20 20 20 20 20 20 66 6f 72 65 61 forea
17f0: 63 68 20 28 43 75 73 74 6f 6d 65 72 73 20 63 75 ch (Customers cu
1800: 73 74 6f 6d 65 72 73 20 69 6e 20 71 75 65 72 79 stomers in query
1810: 29 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 )..
1820: 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 {..
1830: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 69 66 if
1840: 20 28 6f 6e 63 65 29 0d 0a 20 20 20 20 20 20 20 (once)..
1850: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
1860: 20 20 20 43 6f 6e 73 6f 6c 65 2e 57 72 69 74 65 Console.Write
1870: 28 27 20 27 29 3b 0d 0a 0d 0a 20 20 20 20 20 20 (' ');....
1880: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
1890: 43 6f 6e 73 6f 6c 65 2e 57 72 69 74 65 28 63 75 Console.Write(cu
18a0: 73 74 6f 6d 65 72 73 2e 43 75 73 74 6f 6d 65 72 stomers.Customer
18b0: 49 44 29 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20 ID);....
18c0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 6f 6e on
18d0: 63 65 20 3d 20 74 72 75 65 3b 0d 0a 20 20 20 20 ce = true;..
18e0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7d 0d }.
18f0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7d . }
1900: 0d 0a 20 20 20 20 20 20 20 20 20 20 7d 0d 0a 0d .. }...
1910: 0a 20 20 20 20 20 20 20 20 20 20 72 65 74 75 72 . retur
1920: 6e 20 30 3b 0d 0a 20 20 20 20 20 20 7d 0d 0a 0d n 0;.. }...
1930: 0a 20 20 20 20 20 20 2f 2f 0d 0a 20 20 20 20 20 . //..
1940: 20 2f 2f 20 4e 4f 54 45 3a 20 55 73 65 64 20 74 // NOTE: Used t
1950: 6f 20 74 65 73 74 20 74 68 65 20 66 69 78 20 66 o test the fix f
1960: 6f 72 20 74 69 63 6b 65 74 20 5b 35 39 65 64 63 or ticket [59edc
1970: 31 30 31 38 62 5d 2e 0d 0a 20 20 20 20 20 20 2f 1018b]... /
1980: 2f 0d 0a 20 20 20 20 20 20 70 72 69 76 61 74 65 /.. private
1990: 20 73 74 61 74 69 63 20 69 6e 74 20 45 6e 64 73 static int Ends
19a0: 57 69 74 68 54 65 73 74 28 73 74 72 69 6e 67 20 WithTest(string
19b0: 76 61 6c 75 65 29 0d 0a 20 20 20 20 20 20 7b 0d value).. {.
19c0: 0a 20 20 20 20 20 20 20 20 20 20 75 73 69 6e 67 . using
19d0: 20 28 6e 6f 72 74 68 77 69 6e 64 45 46 45 6e 74 (northwindEFEnt
19e0: 69 74 69 65 73 20 64 62 20 3d 20 6e 65 77 20 6e ities db = new n
19f0: 6f 72 74 68 77 69 6e 64 45 46 45 6e 74 69 74 69 orthwindEFEntiti
1a00: 65 73 28 29 29 0d 0a 20 20 20 20 20 20 20 20 20 es())..
1a10: 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 {..
1a20: 20 20 62 6f 6f 6c 20 6f 6e 63 65 20 3d 20 66 61 bool once = fa
1a30: 6c 73 65 3b 0d 0a 20 20 20 20 20 20 20 20 20 20 lse;..
1a40: 20 20 20 20 76 61 72 20 71 75 65 72 79 20 3d 20 var query =
1a50: 66 72 6f 6d 20 63 20 69 6e 20 64 62 2e 43 75 73 from c in db.Cus
1a60: 74 6f 6d 65 72 73 0d 0a 20 20 20 20 20 20 20 20 tomers..
1a70: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
1a80: 20 20 77 68 65 72 65 20 63 2e 43 69 74 79 2e 45 where c.City.E
1a90: 6e 64 73 57 69 74 68 28 76 61 6c 75 65 29 0d 0a ndsWith(value)..
1aa0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
1ab0: 20 20 20 20 20 20 20 20 20 20 6f 72 64 65 72 62 orderb
1ac0: 79 20 63 2e 43 75 73 74 6f 6d 65 72 49 44 0d 0a y c.CustomerID..
1ad0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
1ae0: 20 20 20 20 20 20 20 20 20 20 73 65 6c 65 63 74 select
1af0: 20 63 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20 20 c;....
1b00: 20 20 20 20 20 66 6f 72 65 61 63 68 20 28 43 75 foreach (Cu
1b10: 73 74 6f 6d 65 72 73 20 63 75 73 74 6f 6d 65 72 stomers customer
1b20: 73 20 69 6e 20 71 75 65 72 79 29 0d 0a 20 20 20 s in query)..
1b30: 20 20 20 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 {..
1b40: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
1b50: 69 66 20 28 6f 6e 63 65 29 0d 0a 20 20 20 20 20 if (once)..
1b60: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
1b70: 20 43 6f 6e 73 6f 6c 65 2e 57 72 69 74 65 28 27 Console.Write('
1b80: 20 27 29 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20 ');....
1b90: 20 20 20 20 20 20 20 20 20 20 43 6f 6e 73 6f 6c Consol
1ba0: 65 2e 57 72 69 74 65 28 63 75 73 74 6f 6d 65 72 e.Write(customer
1bb0: 73 2e 43 75 73 74 6f 6d 65 72 49 44 29 3b 0d 0a s.CustomerID);..
1bc0: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 ..
1bd0: 20 20 20 20 6f 6e 63 65 20 3d 20 74 72 75 65 3b once = true;
1be0: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 ..
1bf0: 7d 0d 0a 20 20 20 20 20 20 20 20 20 20 7d 0d 0a }.. }..
1c00: 0d 0a 20 20 20 20 20 20 20 20 20 20 72 65 74 75 .. retu
1c10: 72 6e 20 30 3b 0d 0a 20 20 20 20 20 20 7d 0d 0a rn 0;.. }..
1c20: 0d 0a 20 20 20 20 20 20 2f 2f 0d 0a 20 20 20 20 .. //..
1c30: 20 20 2f 2f 20 4e 4f 54 45 3a 20 55 73 65 64 20 // NOTE: Used
1c40: 74 6f 20 76 65 72 69 66 79 20 74 68 65 20 62 65 to verify the be
1c50: 68 61 76 69 6f 72 20 66 72 6f 6d 20 74 69 63 6b havior from tick
1c60: 65 74 20 5b 30 30 66 38 36 66 39 37 33 39 5d 2e et [00f86f9739].
1c70: 0d 0a 20 20 20 20 20 20 2f 2f 0d 0a 20 20 20 20 .. //..
1c80: 20 20 70 72 69 76 61 74 65 20 73 74 61 74 69 63 private static
1c90: 20 69 6e 74 20 53 74 61 72 74 73 57 69 74 68 54 int StartsWithT
1ca0: 65 73 74 28 73 74 72 69 6e 67 20 76 61 6c 75 65 est(string value
1cb0: 29 0d 0a 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 ).. {..
1cc0: 20 20 20 20 20 20 75 73 69 6e 67 20 28 6e 6f 72 using (nor
1cd0: 74 68 77 69 6e 64 45 46 45 6e 74 69 74 69 65 73 thwindEFEntities
1ce0: 20 64 62 20 3d 20 6e 65 77 20 6e 6f 72 74 68 77 db = new northw
1cf0: 69 6e 64 45 46 45 6e 74 69 74 69 65 73 28 29 29 indEFEntities())
1d00: 0d 0a 20 20 20 20 20 20 20 20 20 20 7b 0d 0a 20 .. {..
1d10: 20 20 20 20 20 20 20 20 20 20 20 20 20 62 6f 6f boo
1d20: 6c 20 6f 6e 63 65 20 3d 20 66 61 6c 73 65 3b 0d l once = false;.
1d30: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 76 . v
1d40: 61 72 20 71 75 65 72 79 20 3d 20 66 72 6f 6d 20 ar query = from
1d50: 63 20 69 6e 20 64 62 2e 43 75 73 74 6f 6d 65 72 c in db.Customer
1d60: 73 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 s..
1d70: 20 20 20 20 20 20 20 20 20 20 20 20 20 77 68 65 whe
1d80: 72 65 20 63 2e 43 69 74 79 2e 53 74 61 72 74 73 re c.City.Starts
1d90: 57 69 74 68 28 76 61 6c 75 65 29 0d 0a 20 20 20 With(value)..
1da0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
1db0: 20 20 20 20 20 20 20 6f 72 64 65 72 62 79 20 63 orderby c
1dc0: 2e 43 75 73 74 6f 6d 65 72 49 44 0d 0a 20 20 20 .CustomerID..
1dd0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
1de0: 20 20 20 20 20 20 20 73 65 6c 65 63 74 20 63 3b select c;
1df0: 0d 0a 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 ....
1e00: 20 20 66 6f 72 65 61 63 68 20 28 43 75 73 74 6f foreach (Custo
1e10: 6d 65 72 73 20 63 75 73 74 6f 6d 65 72 73 20 69 mers customers i
1e20: 6e 20 71 75 65 72 79 29 0d 0a 20 20 20 20 20 20 n query)..
1e30: 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 {..
1e40: 20 20 20 20 20 20 20 20 20 20 20 20 20 69 66 20 if
1e50: 28 6f 6e 63 65 29 0d 0a 20 20 20 20 20 20 20 20 (once)..
1e60: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 43 6f Co
1e70: 6e 73 6f 6c 65 2e 57 72 69 74 65 28 27 20 27 29 nsole.Write(' ')
1e80: 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20 20 20 20 ;....
1e90: 20 20 20 20 20 20 20 43 6f 6e 73 6f 6c 65 2e 57 Console.W
1ea0: 72 69 74 65 28 63 75 73 74 6f 6d 65 72 73 2e 43 rite(customers.C
1eb0: 75 73 74 6f 6d 65 72 49 44 29 3b 0d 0a 0d 0a 20 ustomerID);....
1ec0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
1ed0: 20 6f 6e 63 65 20 3d 20 74 72 75 65 3b 0d 0a 20 once = true;..
1ee0: 20 20 20 20 20 20 20 20 20 20 20 20 20 7d 0d 0a }..
1ef0: 20 20 20 20 20 20 20 20 20 20 7d 0d 0a 0d 0a 20 }....
1f00: 20 20 20 20 20 20 20 20 20 72 65 74 75 72 6e 20 return
1f10: 30 3b 0d 0a 20 20 20 20 20 20 7d 0d 0a 0d 0a 20 0;.. }....
1f20: 20 20 20 20 20 2f 2f 0d 0a 20 20 20 20 20 20 2f //.. /
1f30: 2f 20 4e 4f 54 45 3a 20 55 73 65 64 20 74 6f 20 / NOTE: Used to
1f40: 74 65 73 74 20 74 68 65 20 66 69 78 20 66 6f 72 test the fix for
1f50: 20 74 69 63 6b 65 74 20 5b 63 63 66 61 36 39 66 ticket [ccfa69f
1f60: 63 33 32 5d 2e 0d 0a 20 20 20 20 20 20 2f 2f 0d c32]... //.
1f70: 0a 20 20 20 20 20 20 70 72 69 76 61 74 65 20 73 . private s
1f80: 74 61 74 69 63 20 69 6e 74 20 45 46 54 72 61 6e tatic int EFTran
1f90: 73 61 63 74 69 6f 6e 54 65 73 74 28 62 6f 6f 6c sactionTest(bool
1fa0: 20 61 64 64 29 0d 0a 20 20 20 20 20 20 7b 0d 0a add).. {..
1fb0: 20 20 20 20 20 20 20 20 20 20 2f 2f 0d 0a 20 20 //..
1fc0: 20 20 20 20 20 20 20 20 2f 2f 20 4e 4f 54 45 3a // NOTE:
1fd0: 20 53 6f 6d 65 20 6f 66 20 74 68 65 73 65 20 74 Some of these t
1fe0: 65 72 72 69 74 6f 72 69 65 73 20 61 6c 72 65 61 erritories alrea
1ff0: 64 79 20 65 78 69 73 74 20 61 6e 64 20 73 68 6f dy exist and sho
2000: 75 6c 64 20 63 61 75 73 65 0d 0a 20 20 20 20 20 uld cause..
2010: 20 20 20 20 20 2f 2f 20 20 20 20 20 20 20 61 6e // an
2020: 20 65 78 63 65 70 74 69 6f 6e 20 74 6f 20 62 65 exception to be
2030: 20 74 68 72 6f 77 6e 20 77 68 65 6e 20 77 65 20 thrown when we
2040: 74 72 79 20 74 6f 20 49 4e 53 45 52 54 20 74 68 try to INSERT th
2050: 65 6d 2e 0d 0a 20 20 20 20 20 20 20 20 20 20 2f em... /
2060: 2f 0d 0a 20 20 20 20 20 20 20 20 20 20 6c 6f 6e /.. lon
2070: 67 5b 5d 20 74 65 72 72 69 74 6f 72 79 49 64 73 g[] territoryIds
2080: 20 3d 20 6e 65 77 20 6c 6f 6e 67 5b 5d 20 7b 0d = new long[] {.
2090: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 .
20a0: 20 20 31 2c 20 20 20 20 32 2c 20 20 20 20 33 2c 1, 2, 3,
20b0: 20 20 20 20 34 2c 20 20 20 20 35 2c 20 2f 2f 20 4, 5, //
20c0: 4e 4f 54 45 3a 20 53 75 63 63 65 73 73 0d 0a 20 NOTE: Success..
20d0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
20e0: 36 2c 20 20 20 20 37 2c 20 20 20 20 38 2c 20 20 6, 7, 8,
20f0: 20 20 39 2c 20 20 20 31 30 2c 20 2f 2f 20 4e 4f 9, 10, // NO
2100: 54 45 3a 20 53 75 63 63 65 73 73 0d 0a 20 20 20 TE: Success..
2110: 20 20 20 20 20 20 20 20 20 20 20 31 35 37 36 2c 1576,
2120: 20 31 35 37 37 2c 20 31 35 37 38 2c 20 31 35 37 1577, 1578, 157
2130: 39 2c 20 31 35 38 30 2c 20 2f 2f 20 4e 4f 54 45 9, 1580, // NOTE
2140: 3a 20 53 75 63 63 65 73 73 0d 0a 20 20 20 20 20 : Success..
2150: 20 20 20 20 20 20 20 20 20 31 35 38 31 2c 20 31 1581, 1
2160: 37 33 30 2c 20 31 38 33 33 2c 20 32 31 31 36 2c 730, 1833, 2116,
2170: 20 32 31 33 39 2c 20 2f 2f 20 4e 4f 54 45 3a 20 2139, // NOTE:
2180: 46 61 69 6c 20 28 31 35 38 31 29 0d 0a 20 20 20 Fail (1581)..
2190: 20 20 20 20 20 20 20 20 20 20 20 32 31 34 30 2c 2140,
21a0: 20 32 31 34 31 20 20 20 20 20 20 20 20 20 20 20 2141
21b0: 20 20 20 20 20 20 20 20 20 2f 2f 20 4e 4f 54 45 // NOTE
21c0: 3a 20 53 6b 69 70 70 65 64 0d 0a 20 20 20 20 20 : Skipped..
21d0: 20 20 20 20 20 7d 3b 0d 0a 0d 0a 20 20 20 20 20 };....
21e0: 20 20 20 20 20 69 66 20 28 61 64 64 29 0d 0a 20 if (add)..
21f0: 20 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 {..
2200: 20 20 20 20 20 20 20 20 20 20 75 73 69 6e 67 20 using
2210: 28 6e 6f 72 74 68 77 69 6e 64 45 46 45 6e 74 69 (northwindEFEnti
2220: 74 69 65 73 20 64 62 20 3d 20 6e 65 77 20 6e 6f ties db = new no
2230: 72 74 68 77 69 6e 64 45 46 45 6e 74 69 74 69 65 rthwindEFEntitie
2240: 73 28 29 29 0d 0a 20 20 20 20 20 20 20 20 20 20 s())..
2250: 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 {..
2260: 20 20 20 20 20 20 20 20 20 75 73 69 6e 67 20 28 using (
2270: 54 72 61 6e 73 61 63 74 69 6f 6e 53 63 6f 70 65 TransactionScope
2280: 20 73 63 6f 70 65 20 3d 20 6e 65 77 20 54 72 61 scope = new Tra
2290: 6e 73 61 63 74 69 6f 6e 53 63 6f 70 65 28 29 29 nsactionScope())
22a0: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 ..
22b0: 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 {..
22c0: 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2f 0d //.
22d0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 .
22e0: 20 20 20 20 20 20 20 2f 2f 20 4e 4f 54 45 3a 20 // NOTE:
22f0: 2a 52 45 51 55 49 52 45 44 2a 20 54 68 69 73 20 *REQUIRED* This
2300: 69 73 20 72 65 71 75 69 72 65 64 20 73 6f 20 74 is required so t
2310: 68 61 74 20 74 68 65 0d 0a 20 20 20 20 20 20 20 hat the..
2320: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f /
2330: 2f 20 20 20 20 20 20 20 45 6e 74 69 74 79 20 46 / Entity F
2340: 72 61 6d 65 77 6f 72 6b 20 69 73 20 70 72 65 76 ramework is prev
2350: 65 6e 74 65 64 20 66 72 6f 6d 20 6f 70 65 6e 69 ented from openi
2360: 6e 67 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 ng..
2370: 20 20 20 20 20 20 20 20 20 20 2f 2f 20 20 20 20 //
2380: 20 20 20 6d 75 6c 74 69 70 6c 65 20 63 6f 6e 6e multiple conn
2390: 65 63 74 69 6f 6e 73 20 74 6f 20 74 68 65 20 75 ections to the u
23a0: 6e 64 65 72 6c 79 69 6e 67 20 53 51 4c 69 74 65 nderlying SQLite
23b0: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 ..
23c0: 20 20 20 20 20 20 20 20 2f 2f 20 20 20 20 20 20 //
23d0: 20 64 61 74 61 62 61 73 65 20 28 69 2e 65 2e 20 database (i.e.
23e0: 77 68 69 63 68 20 77 6f 75 6c 64 20 72 65 73 75 which would resu
23f0: 6c 74 20 69 6e 20 6d 75 6c 74 69 70 6c 65 0d 0a lt in multiple..
2400: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
2410: 20 20 20 20 20 20 2f 2f 20 20 20 20 20 20 20 49 // I
2420: 4d 4d 45 44 49 41 54 45 20 74 72 61 6e 73 61 63 MMEDIATE transac
2430: 74 69 6f 6e 73 2c 20 74 68 65 72 65 62 79 20 66 tions, thereby f
2440: 61 69 6c 69 6e 67 20 5b 6c 61 74 65 72 0d 0a 20 ailing [later..
2450: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
2460: 20 20 20 20 20 2f 2f 20 20 20 20 20 20 20 6f 6e // on
2470: 5d 20 77 69 74 68 20 6c 6f 63 6b 69 6e 67 20 65 ] with locking e
2480: 72 72 6f 72 73 29 2e 0d 0a 20 20 20 20 20 20 20 rrors)...
2490: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f /
24a0: 2f 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 /..
24b0: 20 20 20 20 20 20 20 20 20 64 62 2e 43 6f 6e 6e db.Conn
24c0: 65 63 74 69 6f 6e 2e 4f 70 65 6e 28 29 3b 0d 0a ection.Open();..
24d0: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 ..
24e0: 20 20 20 20 20 20 20 20 66 6f 72 65 61 63 68 20 foreach
24f0: 28 69 6e 74 20 69 64 20 69 6e 20 74 65 72 72 69 (int id in terri
2500: 74 6f 72 79 49 64 73 29 0d 0a 20 20 20 20 20 20 toryIds)..
2510: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
2520: 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 {..
2530: 20 20 20 20 20 20 20 20 20 20 20 20 20 54 65 72 Ter
2540: 72 69 74 6f 72 69 65 73 20 74 65 72 72 69 74 6f ritories territo
2550: 72 69 65 73 20 3d 20 6e 65 77 20 54 65 72 72 69 ries = new Terri
2560: 74 6f 72 69 65 73 28 29 3b 0d 0a 0d 0a 20 20 20 tories();....
2570: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
2580: 20 20 20 20 20 20 20 74 65 72 72 69 74 6f 72 69 territori
2590: 65 73 2e 54 65 72 72 69 74 6f 72 79 49 44 20 3d es.TerritoryID =
25a0: 20 69 64 3b 0d 0a 20 20 20 20 20 20 20 20 20 20 id;..
25b0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
25c0: 74 65 72 72 69 74 6f 72 69 65 73 2e 54 65 72 72 territories.Terr
25d0: 69 74 6f 72 79 44 65 73 63 72 69 70 74 69 6f 6e itoryDescription
25e0: 20 3d 20 53 74 72 69 6e 67 2e 46 6f 72 6d 61 74 = String.Format
25f0: 28 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 (..
2600: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
2610: 20 22 54 65 73 74 20 54 65 72 72 69 74 6f 72 79 "Test Territory
2620: 20 23 7b 30 7d 22 2c 20 69 64 29 3b 0d 0a 20 20 #{0}", id);..
2630: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
2640: 20 20 20 20 20 20 20 20 74 65 72 72 69 74 6f 72 territor
2650: 69 65 73 2e 52 65 67 69 6f 6e 73 20 3d 20 64 62 ies.Regions = db
2660: 2e 52 65 67 69 6f 6e 73 2e 46 69 72 73 74 28 29 .Regions.First()
2670: 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20 20 20 20 ;....
2680: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 64 d
2690: 62 2e 41 64 64 4f 62 6a 65 63 74 28 22 54 65 72 b.AddObject("Ter
26a0: 72 69 74 6f 72 69 65 73 22 2c 20 74 65 72 72 69 ritories", terri
26b0: 74 6f 72 69 65 73 29 3b 0d 0a 20 20 20 20 20 20 tories);..
26c0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
26d0: 7d 0d 0a 0d 0a 20 20 20 20 20 20 20 20 20 20 20 }....
26e0: 20 20 20 20 20 20 20 20 20 20 20 74 72 79 0d 0a try..
26f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
2700: 20 20 20 20 20 20 7b 0d 0a 23 69 66 20 4e 45 54 {..#if NET
2710: 5f 32 30 0d 0a 20 20 20 20 20 20 20 20 20 20 20 _20..
2720: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 64 d
2730: 62 2e 53 61 76 65 43 68 61 6e 67 65 73 28 66 61 b.SaveChanges(fa
2740: 6c 73 65 29 3b 0d 0a 23 65 6c 73 65 0d 0a 20 20 lse);..#else..
2750: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
2760: 20 20 20 20 20 20 20 20 64 62 2e 53 61 76 65 43 db.SaveC
2770: 68 61 6e 67 65 73 28 53 61 76 65 4f 70 74 69 6f hanges(SaveOptio
2780: 6e 73 2e 4e 6f 6e 65 29 3b 0d 0a 23 65 6e 64 69 ns.None);..#endi
2790: 66 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 f..
27a0: 20 20 20 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 }..
27b0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
27c0: 20 20 63 61 74 63 68 20 28 45 78 63 65 70 74 69 catch (Excepti
27d0: 6f 6e 20 65 29 0d 0a 20 20 20 20 20 20 20 20 20 on e)..
27e0: 20 20 20 20 20 20 20 20 20 20 20 20 20 7b 0d 0a {..
27f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
2800: 20 20 20 20 20 20 20 20 20 20 43 6f 6e 73 6f 6c Consol
2810: 65 2e 57 72 69 74 65 4c 69 6e 65 28 65 29 3b 0d e.WriteLine(e);.
2820: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 .
2830: 20 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 20 20 }..
2840: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
2850: 66 69 6e 61 6c 6c 79 0d 0a 20 20 20 20 20 20 20 finally..
2860: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7b {
2870: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 ..
2880: 20 20 20 20 20 20 20 20 20 20 20 20 73 63 6f 70 scop
2890: 65 2e 43 6f 6d 70 6c 65 74 65 28 29 3b 0d 0a 20 e.Complete();..
28a0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
28b0: 20 20 20 20 20 20 20 20 20 64 62 2e 41 63 63 65 db.Acce
28c0: 70 74 41 6c 6c 43 68 61 6e 67 65 73 28 29 3b 0d ptAllChanges();.
28d0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 .
28e0: 20 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 20 20 }..
28f0: 20 20 20 20 20 20 20 20 20 20 20 20 7d 0d 0a 20 }..
2900: 20 20 20 20 20 20 20 20 20 20 20 20 20 7d 0d 0a }..
2910: 20 20 20 20 20 20 20 20 20 20 7d 0d 0a 20 20 20 }..
2920: 20 20 20 20 20 20 20 65 6c 73 65 0d 0a 20 20 20 else..
2930: 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 {..
2940: 20 20 20 20 20 20 20 20 75 73 69 6e 67 20 28 6e using (n
2950: 6f 72 74 68 77 69 6e 64 45 46 45 6e 74 69 74 69 orthwindEFEntiti
2960: 65 73 20 64 62 20 3d 20 6e 65 77 20 6e 6f 72 74 es db = new nort
2970: 68 77 69 6e 64 45 46 45 6e 74 69 74 69 65 73 28 hwindEFEntities(
2980: 29 29 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 ))..
2990: 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 {..
29a0: 20 20 20 20 20 20 20 62 6f 6f 6c 20 6f 6e 63 65 bool once
29b0: 20 3d 20 66 61 6c 73 65 3b 0d 0a 20 20 20 20 20 = false;..
29c0: 20 20 20 20 20 20 20 20 20 20 20 20 20 76 61 72 var
29d0: 20 71 75 65 72 79 20 3d 20 66 72 6f 6d 20 74 20 query = from t
29e0: 69 6e 20 64 62 2e 54 65 72 72 69 74 6f 72 69 65 in db.Territorie
29f0: 73 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 s..
2a00: 20 20 20 20 20 20 20 77 68 65 72 65 20 74 65 72 where ter
2a10: 72 69 74 6f 72 79 49 64 73 2e 41 73 51 75 65 72 ritoryIds.AsQuer
2a20: 79 61 62 6c 65 3c 6c 6f 6e 67 3e 28 29 2e 43 6f yable<long>().Co
2a30: 6e 74 61 69 6e 73 3c 6c 6f 6e 67 3e 28 74 2e 54 ntains<long>(t.T
2a40: 65 72 72 69 74 6f 72 79 49 44 29 0d 0a 20 20 20 erritoryID)..
2a50: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
2a60: 20 6f 72 64 65 72 62 79 20 74 2e 54 65 72 72 69 orderby t.Terri
2a70: 74 6f 72 79 49 44 0d 0a 20 20 20 20 20 20 20 20 toryID..
2a80: 20 20 20 20 20 20 20 20 20 20 20 20 73 65 6c 65 sele
2a90: 63 74 20 74 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 ct t;....
2aa0: 20 20 20 20 20 20 20 20 20 20 20 66 6f 72 65 61 forea
2ab0: 63 68 20 28 54 65 72 72 69 74 6f 72 69 65 73 20 ch (Territories
2ac0: 74 65 72 72 69 74 6f 72 69 65 73 20 69 6e 20 71 territories in q
2ad0: 75 65 72 79 29 0d 0a 20 20 20 20 20 20 20 20 20 uery)..
2ae0: 20 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 {..
2af0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
2b00: 20 20 69 66 20 28 6f 6e 63 65 29 0d 0a 20 20 20 if (once)..
2b10: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
2b20: 20 20 20 20 20 20 20 43 6f 6e 73 6f 6c 65 2e 57 Console.W
2b30: 72 69 74 65 28 27 20 27 29 3b 0d 0a 0d 0a 20 20 rite(' ');....
2b40: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
2b50: 20 20 20 20 43 6f 6e 73 6f 6c 65 2e 57 72 69 74 Console.Writ
2b60: 65 28 74 65 72 72 69 74 6f 72 69 65 73 2e 54 65 e(territories.Te
2b70: 72 72 69 74 6f 72 79 49 44 29 3b 0d 0a 0d 0a 20 rritoryID);....
2b80: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
2b90: 20 20 20 20 20 6f 6e 63 65 20 3d 20 74 72 75 65 once = true
2ba0: 3b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 ;..
2bb0: 20 20 20 20 20 7d 0d 0a 20 20 20 20 20 20 20 20 }..
2bc0: 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 20 20 20 }..
2bd0: 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 20 20 20 20 }....
2be0: 20 20 72 65 74 75 72 6e 20 30 3b 0d 0a 20 20 20 return 0;..
2bf0: 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 20 20 2f 2f }.... //
2c00: 0d 0a 20 20 20 20 20 20 2f 2f 20 4e 4f 54 45 3a .. // NOTE:
2c10: 20 55 73 65 64 20 74 6f 20 74 65 73 74 20 74 68 Used to test th
2c20: 65 20 76 61 72 69 6f 75 73 20 44 61 74 65 54 69 e various DateTi
2c30: 6d 65 20 6d 65 74 68 6f 64 73 2e 0d 0a 20 20 20 me methods...
2c40: 20 20 20 2f 2f 0d 0a 20 20 20 20 20 20 70 72 69 //.. pri
2c50: 76 61 74 65 20 73 74 61 74 69 63 20 69 6e 74 20 vate static int
2c60: 44 61 74 65 54 69 6d 65 54 65 73 74 28 0d 0a 20 DateTimeTest(..
2c70: 20 20 20 20 20 20 20 20 20 53 51 4c 69 74 65 44 SQLiteD
2c80: 61 74 65 46 6f 72 6d 61 74 73 20 64 61 74 65 54 ateFormats dateT
2c90: 69 6d 65 46 6f 72 6d 61 74 2c 0d 0a 20 20 20 20 imeFormat,..
2ca0: 20 20 20 20 20 20 73 74 72 69 6e 67 20 71 75 65 string que
2cb0: 72 79 53 74 72 69 6e 67 2c 0d 0a 20 20 20 20 20 ryString,..
2cc0: 20 20 20 20 20 44 61 74 65 54 69 6d 65 3f 20 64 DateTime? d
2cd0: 61 74 65 54 69 6d 65 0d 0a 20 20 20 20 20 20 20 ateTime..
2ce0: 20 20 20 29 0d 0a 20 20 20 20 20 20 7b 0d 0a 20 ).. {..
2cf0: 20 20 20 20 20 20 20 20 20 75 73 69 6e 67 20 28 using (
2d00: 6e 6f 72 74 68 77 69 6e 64 45 46 45 6e 74 69 74 northwindEFEntit
2d10: 69 65 73 20 64 62 20 3d 20 6e 65 77 20 6e 6f 72 ies db = new nor
2d20: 74 68 77 69 6e 64 45 46 45 6e 74 69 74 69 65 73 thwindEFEntities
2d30: 28 29 29 0d 0a 20 20 20 20 20 20 20 20 20 20 7b ()).. {
2d40: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 ..
2d50: 45 6e 74 69 74 79 43 6f 6e 6e 65 63 74 69 6f 6e EntityConnection
2d60: 20 63 6f 6e 6e 65 63 74 69 6f 6e 20 3d 20 64 62 connection = db
2d70: 2e 43 6f 6e 6e 65 63 74 69 6f 6e 20 61 73 20 45 .Connection as E
2d80: 6e 74 69 74 79 43 6f 6e 6e 65 63 74 69 6f 6e 3b ntityConnection;
2d90: 0d 0a 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 ....
2da0: 20 20 69 66 20 28 63 6f 6e 6e 65 63 74 69 6f 6e if (connection
2db0: 20 3d 3d 20 6e 75 6c 6c 29 0d 0a 20 20 20 20 20 == null)..
2dc0: 20 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 {..
2dd0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 43 6f Co
2de0: 6e 73 6f 6c 65 2e 57 72 69 74 65 4c 69 6e 65 28 nsole.WriteLine(
2df0: 22 6e 6f 74 20 61 6e 20 65 6e 74 69 74 79 20 63 "not an entity c
2e00: 6f 6e 6e 65 63 74 69 6f 6e 22 29 3b 0d 0a 20 20 onnection");..
2e10: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
2e20: 72 65 74 75 72 6e 20 31 3b 0d 0a 20 20 20 20 20 return 1;..
2e30: 20 20 20 20 20 20 20 20 20 7d 0d 0a 0d 0a 20 20 }....
2e40: 20 20 20 20 20 20 20 20 20 20 20 20 53 51 4c 69 SQLi
2e50: 74 65 43 6f 6e 6e 65 63 74 69 6f 6e 20 73 74 6f teConnection sto
2e60: 72 65 43 6f 6e 6e 65 63 74 69 6f 6e 20 3d 0d 0a reConnection =..
2e70: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
2e80: 20 20 63 6f 6e 6e 65 63 74 69 6f 6e 2e 53 74 6f connection.Sto
2e90: 72 65 43 6f 6e 6e 65 63 74 69 6f 6e 20 61 73 20 reConnection as
2ea0: 53 51 4c 69 74 65 43 6f 6e 6e 65 63 74 69 6f 6e SQLiteConnection
2eb0: 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20 20 20 20 ;....
2ec0: 20 20 20 69 66 20 28 73 74 6f 72 65 43 6f 6e 6e if (storeConn
2ed0: 65 63 74 69 6f 6e 20 3d 3d 20 6e 75 6c 6c 29 0d ection == null).
2ee0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7b . {
2ef0: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 ..
2f00: 20 20 20 20 43 6f 6e 73 6f 6c 65 2e 57 72 69 74 Console.Writ
2f10: 65 4c 69 6e 65 28 22 6e 6f 74 20 61 20 53 51 4c eLine("not a SQL
2f20: 69 74 65 20 73 74 6f 72 65 20 63 6f 6e 6e 65 63 ite store connec
2f30: 74 69 6f 6e 22 29 3b 0d 0a 20 20 20 20 20 20 20 tion");..
2f40: 20 20 20 20 20 20 20 20 20 20 20 72 65 74 75 72 retur
2f50: 6e 20 31 3b 0d 0a 20 20 20 20 20 20 20 20 20 20 n 1;..
2f60: 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 20 20 20 }....
2f70: 20 20 20 20 20 20 20 63 6f 6e 6e 65 63 74 69 6f connectio
2f80: 6e 2e 4f 70 65 6e 28 29 3b 20 2f 2a 20 4e 4f 54 n.Open(); /* NOT
2f90: 45 3a 20 46 6f 72 63 65 20 6f 70 65 6e 20 6e 6f E: Force open no
2fa0: 77 2e 20 2a 2f 0d 0a 20 20 20 20 20 20 20 20 20 w. */..
2fb0: 20 20 20 20 20 73 74 6f 72 65 43 6f 6e 6e 65 63 storeConnec
2fc0: 74 69 6f 6e 2e 44 61 74 65 54 69 6d 65 46 6f 72 tion.DateTimeFor
2fd0: 6d 61 74 20 3d 20 64 61 74 65 54 69 6d 65 46 6f mat = dateTimeFo
2fe0: 72 6d 61 74 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 rmat;....
2ff0: 20 20 20 20 20 20 20 62 6f 6f 6c 20 6f 6e 63 65 bool once
3000: 20 3d 20 66 61 6c 73 65 3b 0d 0a 0d 0a 20 20 20 = false;....
3010: 20 20 20 20 20 20 20 20 20 20 20 4f 62 6a 65 63 Objec
3020: 74 50 61 72 61 6d 65 74 65 72 5b 5d 20 70 61 72 tParameter[] par
3030: 61 6d 65 74 65 72 73 20 3d 20 28 64 61 74 65 54 ameters = (dateT
3040: 69 6d 65 20 21 3d 20 6e 75 6c 6c 29 20 3f 0d 0a ime != null) ?..
3050: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
3060: 20 20 6e 65 77 20 4f 62 6a 65 63 74 50 61 72 61 new ObjectPara
3070: 6d 65 74 65 72 5b 5d 20 7b 20 6e 65 77 20 4f 62 meter[] { new Ob
3080: 6a 65 63 74 50 61 72 61 6d 65 74 65 72 28 22 64 jectParameter("d
3090: 74 22 2c 20 64 61 74 65 54 69 6d 65 29 20 7d 20 t", dateTime) }
30a0: 3a 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 :..
30b0: 20 20 20 20 20 6e 65 77 20 4f 62 6a 65 63 74 50 new ObjectP
30c0: 61 72 61 6d 65 74 65 72 5b 5d 20 7b 20 7d 3b 0d arameter[] { };.
30d0: 0a 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 ...
30e0: 20 76 61 72 20 71 75 65 72 79 20 3d 20 64 62 2e var query = db.
30f0: 43 72 65 61 74 65 51 75 65 72 79 3c 4f 72 64 65 CreateQuery<Orde
3100: 72 73 3e 28 71 75 65 72 79 53 74 72 69 6e 67 2c rs>(queryString,
3110: 20 70 61 72 61 6d 65 74 65 72 73 29 3b 0d 0a 0d parameters);...
3120: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 66 . f
3130: 6f 72 65 61 63 68 20 28 4f 72 64 65 72 73 20 6f oreach (Orders o
3140: 72 64 65 72 73 20 69 6e 20 71 75 65 72 79 29 0d rders in query).
3150: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7b . {
3160: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 ..
3170: 20 20 20 20 69 66 20 28 6f 6e 63 65 29 0d 0a 20 if (once)..
3180: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
3190: 20 20 20 20 20 43 6f 6e 73 6f 6c 65 2e 57 72 69 Console.Wri
31a0: 74 65 28 27 20 27 29 3b 0d 0a 0d 0a 20 20 20 20 te(' ');....
31b0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 43 6f Co
31c0: 6e 73 6f 6c 65 2e 57 72 69 74 65 28 6f 72 64 65 nsole.Write(orde
31d0: 72 73 2e 4f 72 64 65 72 49 44 29 3b 0d 0a 0d 0a rs.OrderID);....
31e0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
31f0: 20 20 6f 6e 63 65 20 3d 20 74 72 75 65 3b 0d 0a once = true;..
3200: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7d 0d }.
3210: 0a 20 20 20 20 20 20 20 20 20 20 7d 0d 0a 0d 0a . }....
3220: 20 20 20 20 20 20 20 20 20 20 72 65 74 75 72 6e return
3230: 20 30 3b 0d 0a 20 20 20 20 20 20 7d 0d 0a 0a 20 0;.. }...
3240: 20 20 20 70 72 69 76 61 74 65 20 73 74 61 74 69 private stati
3250: 63 20 69 6e 74 20 4f 6c 64 54 65 73 74 73 28 29 c int OldTests()
3260: 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 75 73 . {.. us
3270: 69 6e 67 20 28 6e 6f 72 74 68 77 69 6e 64 45 46 ing (northwindEF
3280: 45 6e 74 69 74 69 65 73 20 64 62 20 3d 20 6e 65 Entities db = ne
3290: 77 20 6e 6f 72 74 68 77 69 6e 64 45 46 45 6e 74 w northwindEFEnt
32a0: 69 74 69 65 73 28 29 29 0a 20 20 20 20 20 20 7b ities()). {
32b0: 0a 20 20 20 20 20 20 20 20 7b 0a 20 20 20 20 20 . {.
32c0: 20 20 20 20 20 73 74 72 69 6e 67 20 65 6e 74 69 string enti
32d0: 74 79 53 51 4c 20 3d 20 22 53 45 4c 45 43 54 20 tySQL = "SELECT
32e0: 56 41 4c 55 45 20 6f 20 46 52 4f 4d 20 4f 72 64 VALUE o FROM Ord
32f0: 65 72 73 20 41 53 20 6f 20 57 48 45 52 45 20 53 ers AS o WHERE S
3300: 51 4c 69 74 65 2e 44 61 74 65 50 61 72 74 28 27 QLite.DatePart('
3310: 79 79 79 79 27 2c 20 6f 2e 4f 72 64 65 72 44 61 yyyy', o.OrderDa
3320: 74 65 29 20 3d 20 31 39 39 37 3b 22 3b 0a 20 20 te) = 1997;";.
3330: 20 20 20 20 20 20 20 20 4f 62 6a 65 63 74 51 75 ObjectQu
3340: 65 72 79 3c 4f 72 64 65 72 73 3e 20 71 75 65 72 ery<Orders> quer
3350: 79 20 3d 20 64 62 2e 43 72 65 61 74 65 51 75 65 y = db.CreateQue
3360: 72 79 3c 4f 72 64 65 72 73 3e 28 65 6e 74 69 74 ry<Orders>(entit
3370: 79 53 51 4c 29 3b 0a 0a 20 20 20 20 20 20 20 20 ySQL);..
3380: 20 20 66 6f 72 65 61 63 68 20 28 4f 72 64 65 72 foreach (Order
3390: 73 20 6f 20 69 6e 20 71 75 65 72 79 29 0a 20 20 s o in query).
33a0: 20 20 20 20 20 20 20 20 7b 0a 20 20 20 20 20 20 {.
33b0: 20 20 20 20 20 20 43 6f 6e 73 6f 6c 65 2e 57 72 Console.Wr
33c0: 69 74 65 4c 69 6e 65 28 6f 2e 53 68 69 70 50 6f iteLine(o.ShipPo
33d0: 73 74 61 6c 43 6f 64 65 29 3b 0a 20 20 20 20 20 stalCode);.
33e0: 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20 7d }. }
33f0: 0a 0a 20 20 20 20 20 20 20 20 7b 0a 20 20 20 20 .. {.
3400: 20 20 20 20 20 20 76 61 72 20 71 75 65 72 79 20 var query
3410: 3d 20 66 72 6f 6d 20 63 20 69 6e 20 64 62 2e 43 = from c in db.C
3420: 75 73 74 6f 6d 65 72 73 0a 20 20 20 20 20 20 20 ustomers.
3430: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 77 w
3440: 68 65 72 65 20 63 2e 43 69 74 79 20 3d 3d 20 22 here c.City == "
3450: 4c 6f 6e 64 6f 6e 22 0a 20 20 20 20 20 20 20 20 London".
3460: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 6f 72 or
3470: 64 65 72 62 79 20 63 2e 43 6f 6d 70 61 6e 79 4e derby c.CompanyN
3480: 61 6d 65 0a 20 20 20 20 20 20 20 20 20 20 20 20 ame.
3490: 20 20 20 20 20 20 20 20 20 20 73 65 6c 65 63 74 select
34a0: 20 63 3b 0a 0a 20 20 20 20 20 20 20 20 20 20 69 c;.. i
34b0: 6e 74 20 63 63 20 3d 20 71 75 65 72 79 2e 43 6f nt cc = query.Co
34c0: 75 6e 74 28 29 3b 0a 0a 20 20 20 20 20 20 20 20 unt();..
34d0: 20 20 66 6f 72 65 61 63 68 20 28 43 75 73 74 6f foreach (Custo
34e0: 6d 65 72 73 20 63 20 69 6e 20 71 75 65 72 79 29 mers c in query)
34f0: 0a 20 20 20 20 20 20 20 20 20 20 7b 0a 20 20 20 . {.
3500: 20 20 20 20 20 20 20 20 20 43 6f 6e 73 6f 6c 65 Console
3510: 2e 57 72 69 74 65 4c 69 6e 65 28 63 2e 43 6f 6d .WriteLine(c.Com
3520: 70 61 6e 79 4e 61 6d 65 29 3b 0a 20 20 20 20 20 panyName);.
3530: 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20 7d }. }
3540: 0a 0a 20 20 20 20 20 20 20 20 7b 0a 20 20 20 20 .. {.
3550: 20 20 20 20 20 20 73 74 72 69 6e 67 20 73 63 69 string sci
3560: 74 79 20 3d 20 22 4c 6f 6e 64 6f 6e 22 3b 0a 20 ty = "London";.
3570: 20 20 20 20 20 20 20 20 20 43 75 73 74 6f 6d 65 Custome
3580: 72 73 20 63 20 3d 20 64 62 2e 43 75 73 74 6f 6d rs c = db.Custom
3590: 65 72 73 2e 46 69 72 73 74 4f 72 44 65 66 61 75 ers.FirstOrDefau
35a0: 6c 74 28 63 64 20 3d 3e 20 63 64 2e 43 69 74 79 lt(cd => cd.City
35b0: 20 3d 3d 20 73 63 69 74 79 29 3b 0a 20 20 20 20 == scity);.
35c0: 20 20 20 20 20 20 43 6f 6e 73 6f 6c 65 2e 57 72 Console.Wr
35d0: 69 74 65 4c 69 6e 65 28 63 2e 43 6f 6d 70 61 6e iteLine(c.Compan
35e0: 79 4e 61 6d 65 29 3b 0a 20 20 20 20 20 20 20 20 yName);.
35f0: 7d 0a 0a 20 20 20 20 20 20 20 20 7b 0a 20 20 20 }.. {.
3600: 20 20 20 20 20 20 20 44 61 74 65 54 69 6d 65 20 DateTime
3610: 64 74 20 3d 20 6e 65 77 20 44 61 74 65 54 69 6d dt = new DateTim
3620: 65 28 31 39 39 37 2c 20 31 2c 20 31 29 3b 0a 20 e(1997, 1, 1);.
3630: 20 20 20 20 20 20 20 20 20 76 61 72 20 71 75 65 var que
3640: 72 79 20 3d 20 66 72 6f 6d 20 6f 72 64 65 72 20 ry = from order
3650: 69 6e 20 64 62 2e 4f 72 64 65 72 73 0a 20 20 20 in db.Orders.
3660: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
3670: 20 20 20 77 68 65 72 65 20 6f 72 64 65 72 2e 4f where order.O
3680: 72 64 65 72 44 61 74 65 20 3c 20 64 74 0a 20 20 rderDate < dt.
3690: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
36a0: 20 20 20 20 73 65 6c 65 63 74 20 6f 72 64 65 72 select order
36b0: 3b 0a 0a 20 20 20 20 20 20 20 20 20 20 66 6f 72 ;.. for
36c0: 65 61 63 68 20 28 4f 72 64 65 72 73 20 6f 20 69 each (Orders o i
36d0: 6e 20 71 75 65 72 79 29 0a 20 20 20 20 20 20 20 n query).
36e0: 20 20 20 7b 0a 20 20 20 20 20 20 20 20 20 20 20 {.
36f0: 20 43 6f 6e 73 6f 6c 65 2e 57 72 69 74 65 4c 69 Console.WriteLi
3700: 6e 65 28 6f 2e 4f 72 64 65 72 44 61 74 65 2e 54 ne(o.OrderDate.T
3710: 6f 53 74 72 69 6e 67 28 29 29 3b 0a 20 20 20 20 oString());.
3720: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20 }.
3730: 7d 0a 0a 20 20 20 20 20 20 20 20 7b 0a 20 20 20 }.. {.
3740: 20 20 20 20 20 20 20 43 61 74 65 67 6f 72 69 65 Categorie
3750: 73 20 63 20 3d 20 6e 65 77 20 43 61 74 65 67 6f s c = new Catego
3760: 72 69 65 73 28 29 3b 0a 20 20 20 20 20 20 20 20 ries();.
3770: 20 20 63 2e 43 61 74 65 67 6f 72 79 4e 61 6d 65 c.CategoryName
3780: 20 3d 20 22 54 65 73 74 20 43 61 74 65 67 6f 72 = "Test Categor
3790: 79 22 3b 0a 20 20 20 20 20 20 20 20 20 20 63 2e y";. c.
37a0: 44 65 73 63 72 69 70 74 69 6f 6e 20 3d 20 22 4d Description = "M
37b0: 79 20 44 65 73 63 72 69 70 74 69 6f 6e 22 3b 0a y Description";.
37c0: 20 20 20 20 20 20 20 20 20 20 64 62 2e 41 64 64 db.Add
37d0: 54 6f 43 61 74 65 67 6f 72 69 65 73 28 63 29 3b ToCategories(c);
37e0: 0a 20 20 20 20 20 20 20 20 20 20 64 62 2e 53 61 . db.Sa
37f0: 76 65 43 68 61 6e 67 65 73 28 29 3b 0a 0a 20 20 veChanges();..
3800: 20 20 20 20 20 20 20 20 43 6f 6e 73 6f 6c 65 2e Console.
3810: 57 72 69 74 65 4c 69 6e 65 28 63 2e 43 61 74 65 WriteLine(c.Cate
3820: 67 6f 72 79 49 44 29 3b 0a 0a 20 20 20 20 20 20 goryID);..
3830: 20 20 20 20 63 2e 44 65 73 63 72 69 70 74 69 6f c.Descriptio
3840: 6e 20 3d 20 22 4d 79 20 6d 6f 64 69 66 69 65 64 n = "My modified
3850: 20 64 65 73 63 72 69 70 74 69 6f 6e 22 3b 0a 20 description";.
3860: 20 20 20 20 20 20 20 20 20 64 62 2e 53 61 76 65 db.Save
3870: 43 68 61 6e 67 65 73 28 29 3b 0a 0a 20 20 20 20 Changes();..
3880: 20 20 20 20 20 20 64 62 2e 44 65 6c 65 74 65 4f db.DeleteO
3890: 62 6a 65 63 74 28 63 29 3b 0a 20 20 20 20 20 20 bject(c);.
38a0: 20 20 20 20 64 62 2e 53 61 76 65 43 68 61 6e 67 db.SaveChang
38b0: 65 73 28 29 3b 0a 20 20 20 20 20 20 20 20 7d 0a es();. }.
38c0: 0a 20 20 20 20 20 20 20 20 7b 0a 20 20 20 20 20 . {.
38d0: 20 20 20 20 20 43 75 73 74 6f 6d 65 72 73 20 63 Customers c
38e0: 75 73 74 20 3d 20 6e 65 77 20 43 75 73 74 6f 6d ust = new Custom
38f0: 65 72 73 28 29 3b 0a 20 20 20 20 20 20 20 20 20 ers();.
3900: 20 63 75 73 74 2e 43 75 73 74 6f 6d 65 72 49 44 cust.CustomerID
3910: 20 3d 20 22 4d 54 4d 54 4d 22 3b 0a 20 20 20 20 = "MTMTM";.
3920: 20 20 20 20 20 20 63 75 73 74 2e 43 6f 6e 74 61 cust.Conta
3930: 63 74 4e 61 6d 65 20 3d 20 22 4d 79 20 4e 61 6d ctName = "My Nam
3940: 65 22 3b 0a 20 20 20 20 20 20 20 20 20 20 63 75 e";. cu
3950: 73 74 2e 43 6f 6d 70 61 6e 79 4e 61 6d 65 20 3d st.CompanyName =
3960: 20 22 53 51 4c 69 74 65 20 43 6f 6d 70 61 6e 79 "SQLite Company
3970: 22 3b 0a 20 20 20 20 20 20 20 20 20 20 63 75 73 ";. cus
3980: 74 2e 43 6f 75 6e 74 72 79 20 3d 20 22 4e 65 74 t.Country = "Net
3990: 68 65 72 6c 61 6e 64 73 22 3b 0a 20 20 20 20 20 herlands";.
39a0: 20 20 20 20 20 63 75 73 74 2e 43 69 74 79 20 3d cust.City =
39b0: 20 22 41 6d 73 74 65 72 64 61 6d 22 3b 0a 20 20 "Amsterdam";.
39c0: 20 20 20 20 20 20 20 20 63 75 73 74 2e 50 68 6f cust.Pho
39d0: 6e 65 20 3d 20 22 30 31 32 33 34 35 36 37 37 22 ne = "012345677"
39e0: 3b 0a 20 20 20 20 20 20 20 20 20 20 64 62 2e 41 ;. db.A
39f0: 64 64 54 6f 43 75 73 74 6f 6d 65 72 73 28 63 75 ddToCustomers(cu
3a00: 73 74 29 3b 0a 20 20 20 20 20 20 20 20 20 20 64 st);. d
3a10: 62 2e 53 61 76 65 43 68 61 6e 67 65 73 28 29 3b b.SaveChanges();
3a20: 0a 0a 20 20 20 20 20 20 20 20 20 20 64 62 2e 44 .. db.D
3a30: 65 6c 65 74 65 4f 62 6a 65 63 74 28 63 75 73 74 eleteObject(cust
3a40: 29 3b 0a 20 20 20 20 20 20 20 20 20 20 64 62 2e );. db.
3a50: 53 61 76 65 43 68 61 6e 67 65 73 28 29 3b 0a 20 SaveChanges();.
3a60: 20 20 20 20 20 20 20 7d 0a 0a 20 20 20 20 20 20 }..
3a70: 20 20 7b 0a 20 20 20 20 20 20 20 20 20 20 76 61 {. va
3a80: 72 20 71 75 65 72 79 20 3d 20 64 62 2e 43 75 73 r query = db.Cus
3a90: 74 6f 6d 65 72 73 2e 57 68 65 72 65 28 63 75 73 tomers.Where(cus
3aa0: 74 20 3d 3e 20 63 75 73 74 2e 43 6f 75 6e 74 72 t => cust.Countr
3ab0: 79 20 3d 3d 20 22 44 65 6e 6d 61 72 6b 22 29 0a y == "Denmark").
3ac0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
3ad0: 20 20 20 20 20 20 20 20 20 20 2e 53 65 6c 65 63 .Selec
3ae0: 74 4d 61 6e 79 28 63 75 73 74 20 3d 3e 20 63 75 tMany(cust => cu
3af0: 73 74 2e 4f 72 64 65 72 73 2e 57 68 65 72 65 28 st.Orders.Where(
3b00: 6f 20 3d 3e 20 6f 2e 46 72 65 69 67 68 74 20 3e o => o.Freight >
3b10: 20 35 29 29 3b 0a 0a 20 20 20 20 20 20 20 20 20 5));..
3b20: 20 66 6f 72 65 61 63 68 20 28 4f 72 64 65 72 73 foreach (Orders
3b30: 20 63 20 69 6e 20 71 75 65 72 79 29 0a 20 20 20 c in query).
3b40: 20 20 20 20 20 20 20 7b 0a 20 20 20 20 20 20 20 {.
3b50: 20 20 20 20 20 43 6f 6e 73 6f 6c 65 2e 57 72 69 Console.Wri
3b60: 74 65 4c 69 6e 65 28 63 2e 46 72 65 69 67 68 74 teLine(c.Freight
3b70: 29 3b 0a 20 20 20 20 20 20 20 20 20 20 7d 0a 20 );. }.
3b80: 20 20 20 20 20 20 20 7d 0a 0a 20 20 20 20 20 20 }..
3b90: 20 20 7b 0a 20 20 20 20 20 20 20 20 20 20 76 61 {. va
3ba0: 72 20 71 75 65 72 79 20 3d 20 66 72 6f 6d 20 63 r query = from c
3bb0: 20 69 6e 20 64 62 2e 43 75 73 74 6f 6d 65 72 73 in db.Customers
3bc0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 .
3bd0: 20 20 20 20 20 20 20 77 68 65 72 65 20 63 2e 4f where c.O
3be0: 72 64 65 72 73 2e 41 6e 79 28 6f 20 3d 3e 20 6f rders.Any(o => o
3bf0: 2e 4f 72 64 65 72 44 61 74 65 2e 48 61 73 56 61 .OrderDate.HasVa
3c00: 6c 75 65 20 3d 3d 20 74 72 75 65 20 26 26 20 6f lue == true && o
3c10: 2e 4f 72 64 65 72 44 61 74 65 2e 56 61 6c 75 65 .OrderDate.Value
3c20: 2e 59 65 61 72 20 3d 3d 20 31 39 39 37 29 0a 20 .Year == 1997).
3c30: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
3c40: 20 20 20 20 20 73 65 6c 65 63 74 20 63 3b 0a 0a select c;..
3c50: 20 20 20 20 20 20 20 20 20 20 66 6f 72 65 61 63 foreac
3c60: 68 20 28 43 75 73 74 6f 6d 65 72 73 20 63 20 69 h (Customers c i
3c70: 6e 20 71 75 65 72 79 29 0a 20 20 20 20 20 20 20 n query).
3c80: 20 20 20 7b 0a 20 20 20 20 20 20 20 20 20 20 20 {.
3c90: 20 43 6f 6e 73 6f 6c 65 2e 57 72 69 74 65 4c 69 Console.WriteLi
3ca0: 6e 65 28 63 2e 43 6f 6d 70 61 6e 79 4e 61 6d 65 ne(c.CompanyName
3cb0: 29 3b 0a 20 20 20 20 20 20 20 20 20 20 7d 0a 20 );. }.
3cc0: 20 20 20 20 20 20 20 7d 0a 0a 20 20 20 20 20 20 }..
3cd0: 20 20 7b 0a 20 20 20 20 20 20 20 20 20 20 73 74 {. st
3ce0: 72 69 6e 67 20 65 6e 74 69 74 79 53 51 4c 20 3d ring entitySQL =
3cf0: 20 22 53 45 4c 45 43 54 20 56 41 4c 55 45 20 6f "SELECT VALUE o
3d00: 20 46 52 4f 4d 20 4f 72 64 65 72 73 20 41 53 20 FROM Orders AS
3d10: 6f 20 57 48 45 52 45 20 6f 2e 43 75 73 74 6f 6d o WHERE o.Custom
3d20: 65 72 73 2e 43 6f 75 6e 74 72 79 20 3c 3e 20 27 ers.Country <> '
3d30: 55 4b 27 20 41 4e 44 20 6f 2e 43 75 73 74 6f 6d UK' AND o.Custom
3d40: 65 72 73 2e 43 6f 75 6e 74 72 79 20 3c 3e 20 27 ers.Country <> '
3d50: 4d 65 78 69 63 6f 27 20 41 4e 44 20 59 65 61 72 Mexico' AND Year
3d60: 28 6f 2e 4f 72 64 65 72 44 61 74 65 29 20 3d 20 (o.OrderDate) =
3d70: 31 39 39 37 3b 22 3b 0a 20 20 20 20 20 20 20 20 1997;";.
3d80: 20 20 4f 62 6a 65 63 74 51 75 65 72 79 3c 4f 72 ObjectQuery<Or
3d90: 64 65 72 73 3e 20 71 75 65 72 79 20 3d 20 64 62 ders> query = db
3da0: 2e 43 72 65 61 74 65 51 75 65 72 79 3c 4f 72 64 .CreateQuery<Ord
3db0: 65 72 73 3e 28 65 6e 74 69 74 79 53 51 4c 29 3b ers>(entitySQL);
3dc0: 0a 0a 20 20 20 20 20 20 20 20 20 20 66 6f 72 65 .. fore
3dd0: 61 63 68 20 28 4f 72 64 65 72 73 20 6f 20 69 6e ach (Orders o in
3de0: 20 71 75 65 72 79 29 0a 20 20 20 20 20 20 20 20 query).
3df0: 20 20 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20 {.
3e00: 43 6f 6e 73 6f 6c 65 2e 57 72 69 74 65 4c 69 6e Console.WriteLin
3e10: 65 28 6f 2e 53 68 69 70 50 6f 73 74 61 6c 43 6f e(o.ShipPostalCo
3e20: 64 65 29 3b 0a 20 20 20 20 20 20 20 20 20 20 7d de);. }
3e30: 0a 20 20 20 20 20 20 20 20 7d 0a 0a 20 20 20 20 . }..
3e40: 20 20 20 20 7b 0a 20 20 20 20 20 20 20 20 20 20 {.
3e50: 73 74 72 69 6e 67 20 65 6e 74 69 74 79 53 51 4c string entitySQL
3e60: 20 3d 20 22 53 45 4c 45 43 54 20 56 41 4c 55 45 = "SELECT VALUE
3e70: 20 6f 20 46 52 4f 4d 20 4f 72 64 65 72 73 20 41 o FROM Orders A
3e80: 53 20 6f 20 57 48 45 52 45 20 4e 65 77 47 75 69 S o WHERE NewGui
3e90: 64 28 29 20 3c 3e 20 4e 65 77 47 75 69 64 28 29 d() <> NewGuid()
3ea0: 3b 22 3b 0a 20 20 20 20 20 20 20 20 20 20 4f 62 ;";. Ob
3eb0: 6a 65 63 74 51 75 65 72 79 3c 4f 72 64 65 72 73 jectQuery<Orders
3ec0: 3e 20 71 75 65 72 79 20 3d 20 64 62 2e 43 72 65 > query = db.Cre
3ed0: 61 74 65 51 75 65 72 79 3c 4f 72 64 65 72 73 3e ateQuery<Orders>
3ee0: 28 65 6e 74 69 74 79 53 51 4c 29 3b 0a 0a 20 20 (entitySQL);..
3ef0: 20 20 20 20 20 20 20 20 66 6f 72 65 61 63 68 20 foreach
3f00: 28 4f 72 64 65 72 73 20 6f 20 69 6e 20 71 75 65 (Orders o in que
3f10: 72 79 29 0a 20 20 20 20 20 20 20 20 20 20 7b 0a ry). {.
3f20: 20 20 20 20 20 20 20 20 20 20 20 20 43 6f 6e 73 Cons
3f30: 6f 6c 65 2e 57 72 69 74 65 4c 69 6e 65 28 6f 2e ole.WriteLine(o.
3f40: 53 68 69 70 50 6f 73 74 61 6c 43 6f 64 65 29 3b ShipPostalCode);
3f50: 0a 20 20 20 20 20 20 20 20 20 20 7d 0a 20 20 20 . }.
3f60: 20 20 20 20 20 7d 0a 0a 20 20 20 20 20 20 20 20 }..
3f70: 2f 2f 20 54 68 69 73 20 71 75 65 72 79 20 72 65 // This query re
3f80: 71 75 69 72 65 73 20 53 51 4c 69 74 65 20 33 2e quires SQLite 3.
3f90: 36 2e 32 20 74 6f 20 66 75 6e 63 74 69 6f 6e 20 6.2 to function
3fa0: 63 6f 72 72 65 63 74 6c 79 0a 20 20 20 20 20 20 correctly.
3fb0: 20 20 7b 0a 20 20 20 20 20 20 20 20 20 20 76 61 {. va
3fc0: 72 20 71 75 65 72 79 20 3d 20 66 72 6f 6d 20 70 r query = from p
3fd0: 20 69 6e 20 64 62 2e 50 72 6f 64 75 63 74 73 0a in db.Products.
3fe0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
3ff0: 20 20 20 20 20 20 77 68 65 72 65 20 70 2e 4f 72 where p.Or
4000: 64 65 72 44 65 74 61 69 6c 73 2e 43 6f 75 6e 74 derDetails.Count
4010: 28 6f 64 20 3d 3e 20 6f 64 2e 4f 72 64 65 72 73 (od => od.Orders
4020: 2e 43 75 73 74 6f 6d 65 72 73 2e 43 6f 75 6e 74 .Customers.Count
4030: 72 79 20 3d 3d 20 70 2e 53 75 70 70 6c 69 65 72 ry == p.Supplier
4040: 73 2e 43 6f 75 6e 74 72 79 29 20 3e 20 32 0a 20 s.Country) > 2.
4050: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
4060: 20 20 20 20 20 73 65 6c 65 63 74 20 70 3b 0a 0a select p;..
4070: 20 20 20 20 20 20 20 20 20 20 66 6f 72 65 61 63 foreac
4080: 68 20 28 50 72 6f 64 75 63 74 73 20 70 20 69 6e h (Products p in
4090: 20 71 75 65 72 79 29 0a 20 20 20 20 20 20 20 20 query).
40a0: 20 20 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20 {.
40b0: 43 6f 6e 73 6f 6c 65 2e 57 72 69 74 65 4c 69 6e Console.WriteLin
40c0: 65 28 70 2e 50 72 6f 64 75 63 74 4e 61 6d 65 29 e(p.ProductName)
40d0: 3b 0a 20 20 20 20 20 20 20 20 20 20 7d 0a 20 20 ;. }.
40e0: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 7d 0a }. }.
40f0: 0a 20 20 20 20 20 20 2f 2f 0a 20 20 20 20 20 20 . //.
4100: 2f 2f 20 4e 4f 54 45 3a 20 28 4a 4a 4d 29 20 52 // NOTE: (JJM) R
4110: 65 6d 6f 76 65 64 20 6f 6e 20 32 30 31 31 2f 30 emoved on 2011/0
4120: 37 2f 30 36 2c 20 6d 61 6b 65 73 20 69 74 20 68 7/06, makes it h
4130: 61 72 64 65 72 20 74 6f 20 72 75 6e 20 74 68 69 arder to run thi
4140: 73 20 45 58 45 20 76 69 61 0a 20 20 20 20 20 20 s EXE via.
4150: 2f 2f 20 20 20 20 20 20 20 74 68 65 20 6e 65 77 // the new
4160: 20 75 6e 69 74 20 74 65 73 74 20 73 75 69 74 65 unit test suite
4170: 2e 0a 20 20 20 20 20 20 2f 2f 0a 20 20 20 20 20 .. //.
4180: 20 2f 2f 20 43 6f 6e 73 6f 6c 65 2e 52 65 61 64 // Console.Read
4190: 4b 65 79 28 29 3b 0d 0a 0d 0a 20 20 20 20 20 20 Key();....
41a0: 72 65 74 75 72 6e 20 30 3b 0a 20 20 20 20 7d 0a return 0;. }.
41b0: 20 20 7d 0a 7d 0a }.}.