Итак, для начала вы прошли через этот код с помощью отладчика и определили, генерирует ли он исключение или возвращает измененные нулевые строки?
Самое неприятное - это вставка @IDколонка.Если это столбец Identity, вы не должны вставлять это значение.Если это не так, я не вижу, чтобы вы где-либо присваивали ему значение.
РЕДАКТИРОВАТЬ:
Так что, как уже упоминалось здесь, у вас есть некоторые структурные проблемы в вашем запросе.
Я взял ваш код и бросил его в быстрый проект, и вот как выглядит ваше утверждение.
INSERT INTO User Values('@ID,UserName','FirstName','LastName','123 Some Street','SomeTown','State','54555','555-444-3333','email@email.com','ITS_A_SECRET!
Обратите внимание на конец запроса.Поле пароля не может быть закрыто при закрытии ', а список параметров не закрыт закрывающей скобкой.

Вторая проблема заключается в том, что поле @Id.Является ли ваш столбец в базе данных полем идентификации?(Так и должно быть) Если это так, просто удалите это.
Теперь вот настоящий кикер.Ваше имя пользователя в таблице?Это зарезервированное слово в SQL-сервере, поэтому вы получите ошибки в своем запросе как есть.Отформатируйте запрос так, как показано ниже, и он будет работать.
string storedProcText = ("INSERT INTO [dbo].[User] Values('" + strUname + "','" + strFname + "','" + strLname + "','" + address + "','" + city + "','" + state + "','" + zip + "','" + phone + "','" + email + "','" + password + "')");

Другая проблема, как уже упоминалось, заключается в том, что тип команды установлен на «Хранимая процедура», когда вы этого не делаете.используя один.
Изменение типа вашей команды на текст:
myCommand.CommandType = CommandType.Text;

После того, как я внес эти изменения и запустил ваш код, я получил запись в базе данных.

Самое важное, что нужно проверить прямо сейчас, это поле идентификатора.Это столбец идентификации?Убедитесь, что это так, а затем удалите его из своего заявления.