DataContext.CreateDatabase создает базу данных со столбцами в случайном порядке. - PullRequest
4 голосов
/ 22 августа 2011

У меня есть настольное приложение c # .Net, в котором я использую Linq в качестве ORM и SQL Server Express в качестве базы данных. Поэтому, когда я использую метод dataContext.CreateDatabase (), 90% случаев он создает столбцы в том же порядке, что и в linq.cs. В этих оставшихся 10% порядок нескольких столбцов перемешан. (указанные проценты являются приблизительными. Linq.cs генерируется из SqlMetal)

Есть ли конкретная причина, почему это происходит, или есть какие-то настройки для управления этим ..? Я подумал об использовании порядка, поскольку число столбцов составляет около 30. И есть 15-20 таблиц как таковых.

UPDATE

Мы используем базу данных гибридным способом (т.е. также выполняем команды SQL напрямую). Это одна из причин, почему я ищу порядок столбцов.

1 Ответ

4 голосов
/ 22 августа 2011

В своих внутренних элементах LINQ-to-SQL использует язык SQL.Когда он создает таблицы, если вы регистрируете свой SQL Server, вы увидите операторы SQL, например, ALTER TABLE ADD COLUMN ...

ADD COLUMN не позволяет устанавливать позицию столбца.В более общем смысле, SQL (язык, будь то Oracle, MySQL или SQLServer) не предоставляет инструментов для управления положением столбцов, поэтому порядок столбцов зависит только от порядка их создания.

Такое поведение предназначено.Вы не должны полагаться на порядок столбцов никогда.Большинство платформ доступа к данным явно рекомендуют это, и они не гарантируют постоянство порядка столбцов, которые у вас есть в любой точке.

Кроме того, в вашем случае вы используете LINQ-to-SQL, поэтомуесли вы не собираетесь использовать его гибридным способом (то есть также выполнять команды SQL напрямую), порядок не будет иметь значения, поскольку вы будете получать доступ к столбцам через соответствующие именованные свойства.

Итак, если вы действительно используете его вгибридный способ, обязательно всегда указывайте имена столбцов при выполнении SqlCommands.Не пишите INSERT INTO MYTABLE VALUES (1,2,3), пишите вместо INSERT INTO MYTABLE(COL1, COL2, COL3) VALUES (1,2,3).

Кроме того, я не совсем понимаю, почему вы говорите, что собираетесь использовать порядок, поскольку имеется 30 столбцов.Во-первых, 30 не является высоким (равно как и 20 таблиц), а во-вторых, если они могут быть вызваны по их положению (например, ADDRESS1, ADDRESS2, ADDRESS3), это обычно означает, что структура базы данных имеет недостатки.См 1-я нормальная форма .

...