
I tried to use this trick with LINQ:

but unfortunately it doesn't work. The cities weren't randomized at all. It turned out what during SQL query generation Guid.NewGuid() was treated as a constant and was ignored as the same for all records.
So the right way in this case is to call AsEnumerable() first:

Another interesting thing is what enumerating ci now gives different results every time, so this code might give wrong result:

other might contain first element anyway because records are randomized during second use of ci variable. To avoid this side effect we need to "freeze" elements with ToList():

After that the result will be as expected.