Форум программистов, компьютерный форум, киберфорум
C#: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.92/13: Рейтинг темы: голосов - 13, средняя оценка - 4.92
0 / 0 / 0
Регистрация: 18.03.2017
Сообщений: 85

Не удается неявно преобразить тип

26.10.2020, 20:36. Показов 2980. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый вечер, не понимаю как исправить или сделать лучше. Пытаюсь составить выражение СтоимостьЗаДень * days, но появляется ошибка что "Не удается неявно преобразить тип "object" в "int". Существует явно преобразование." Насколько я понял СтоимостьЗаДень имеет тип object, но я не могу понять как изменить тип на int, чтобы выражение работало. Можете подсказать?
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
            DateTime registrationDate = DateTime.Now;
            DateTime registrationDate1 = monthCalendar1.SelectionStart;
            TimeSpan ts = registrationDate1 - registrationDate;
            int days = ts.Days;
            using (var con = new SqlConnection(@"Data Source (LocalDB)\MSSQLLocalDB;AttachDbFilename=|DataDirectory|\SharingBase.mdf;Integrated Security=True"))
                if (textBox4.Text != "" && textBox3.Text != "")
                {
                    string s = "SELECT СтоимостьЗаДень FROM [Продукция] WHERE КодПродукции ='" + textBox3.Text + "'";
                    SqlCommand brm = new SqlCommand(s, con);
                    con.Open();
                    object СтоимостьЗаДень = brm.ExecuteScalar();
                    Convert.ToInt64(СтоимостьЗаДень);
                    int cena = СтоимостьЗаДень * days;
                }
 
            textBox2.Text = cena.ToString();
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
26.10.2020, 20:36
Ответы с готовыми решениями:

Не удается неявно преобразовать тип string в тип bool
Должно выводиться имя студента, его возраст и есть ли у него стипендия. using System; using System.Collections.Generic; using...

Не удается неявно преобразовать тип double в тип bool
static double func1 (double x) { double y = x + 1; return y; } static void...

Не удается неявно преобразовать тип double в тип int
class Program { static void Main(string args) { double k = 0; Random r = new...

7
1497 / 1238 / 245
Регистрация: 04.04.2011
Сообщений: 4,363
27.10.2020, 02:07
Вместо

C#
1
object ПовбывавБыТехКтоПишетКириллицей = brm.ExecuteScalar();
напишите

C#
1
int ПовбывавБыТехКтоПишетКириллицей = brm.ExecuteScalar();
1
0 / 0 / 0
Регистрация: 18.03.2017
Сообщений: 85
27.10.2020, 14:06  [ТС]
Спасибо, но теперь ругается на эту строку на переменную brm
C#
1
int СтоимостьЗаДень = brm.ExecuteScalar();
Такая же ошибка как и раньше
0
1497 / 1238 / 245
Регистрация: 04.04.2011
Сообщений: 4,363
27.10.2020, 14:48
Лучший ответ Сообщение было отмечено Sibya как решение

Решение

Какой тип данных определен для поля СтоимостьЗаДень в таблице Продукция ?

Посмотрите в отладчике что в этом brm.

Добавлено через 3 минуты
Вы пробовали выполнить этот запрос в SSMS ? Что он возвращает ?
И как ругается ? Что за ошибка ?
У меня телепатор в ремонте, поэтому на расстоянии не вижу.

На всякий случай:
https://docs.microsoft.com/en-... at-ext-3.1

Добавлено через 4 минуты
Да, и поставьте приведение к нужному типу:
C#
1
Int64 СтоимостьЗаДень = (Int64) brm.ExecuteScalar();
Добавлено через 8 минут
Тип object указывают в случаях, когда неизвестен заранее тип данных, который туда (в переменную) прилетит.
Чтобы потом его проанализировать и привести к нужному для дальнейших операций с данными.
Если же он известен заранее, а в Вашем случает он должен быть известен тип результата запроса должен определяться явно.
Если может быть ситуация, когда в первой колонке первой строки результата запроса может быть null, то следует также это учесть, протипизировав переменную-получатель как int? , а затем проверять ее на null с помощью тернального выражения https://docs.microsoft.com/ru-... l-operator
1
0 / 0 / 0
Регистрация: 18.03.2017
Сообщений: 85
28.10.2020, 16:58  [ТС]
Попробовал как Вы посоветовали, но ошибка осталась

Добавлено через 6 минут
Все получилось. Покурил материал, который Вы предоставили. Вот код)
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
            DateTime registrationDate1 = monthCalendar1.SelectionStart;
            TimeSpan ts = registrationDate1 - registrationDate;
            int days = ts.Days;
            using (var con = new SqlConnection(@"Data Source=(LocalDB)\MSSQLLocalDB;AttachDbFilename=|DataDirectory|\SharingBase.mdf;Integrated Security=True"))
                if (textBox4.Text != "" && textBox3.Text != "")
                {
                    SqlCommand ar = new SqlCommand("SELECT СтоимостьЗаДень FROM [Продукция] WHERE КодПродукции ='" + textBox3.Text + "'", con);
                    string s = "SELECT СтоимостьЗаДень FROM [Продукция] WHERE КодПродукции ='" + textBox3.Text + "'";
                    SqlCommand brm = new SqlCommand(s, con);
                    con.Open();
                    int maxId = Convert.ToInt32(ar.ExecuteScalar());
                    int cena = Convert.ToInt32(maxId * days);
                    textBox2.Text = cena.ToString();
                }
0
1497 / 1238 / 245
Регистрация: 04.04.2011
Сообщений: 4,363
28.10.2020, 17:22
Теперь осталось выкинуть в мусорку этот brm вместе с 's'
0
Эксперт .NET
 Аватар для Usaga
14314 / 9399 / 1355
Регистрация: 21.01.2016
Сообщений: 35,435
29.10.2020, 08:14
Да и само подключение имеет смысл создавать после проверки, а не до.
1
1497 / 1238 / 245
Регистрация: 04.04.2011
Сообщений: 4,363
29.10.2020, 14:01
Цитата Сообщение от Usaga Посмотреть сообщение
Да и само подключение имеет смысл создавать после проверки, а не до.
Весьма концептуально. Я даже не обратил внимание
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
29.10.2020, 14:01
Помогаю со студенческими работами здесь

Не удается неявно преобразовать тип
Здравствуйте. Не понимаю как решить проблему. Нужно удалить из List States повторяющие элементы. List<int> I = States.Distinct(); ...

Не удается неявно преобразовать тип
Продолжаю изучать С#, делая уроки из курса MS. Стоит задача сделать секундомер для UWP. Приложение простое: клик по кнопке и начало отсчета...

Не удаётся неявно преобразовать тип string в byte[]
Добрый вечер. "Позаимствовал" код блочного шифра на C# для своей курсовой, оригинальный код консольный, переделал под Виндоус Формы. В 124...

Не удается неявно преобразовать тип string в char
public Form1() { InitializeComponent(); } public double a; public double b; ...

Не удается неявно преобразовать тип float в int
private void Awake() { if (PlayerPrefs.HasKey("SV")) { float totalBonusPS = 0 ; sv =...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
Вывод диалогового окна перед закрытием, если документ не проведён
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: реализовать программный контроль на предмет проведения документа. . .
Программный контроль заполнения реквизита табличной части документа
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: реализовать контроль заполнения реквизита "ПричинаСписания". . .
wmic не является внутренней или внешней командой
Maks 02.04.2026
Решение: DISM / Online / Add-Capability / CapabilityName:WMIC~~~~ Отсюда: https:/ / winitpro. ru/ index. php/ 2025/ 02/ 14/ komanda-wmic-ne-naydena/
Программная установка даты и запрет ее изменения
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: при создании документов установить период списания автоматически. . .
Вывод данных в справочнике через динамический список
Maks 01.04.2026
Реализация из решения ниже выполнена на примере нетипового справочника "Спецтехника" разработанного в конфигурации КА2. Задача: вывести данные из ТЧ нетипового документа. . .
Программное заполнения текстового поля в реквизите формы документа
Maks 01.04.2026
Алгоритм из решения ниже реализован на нетиповом документе "ВыдачаОборудованияНаСпецтехнику" разработанного в конфигурации КА2, в дополнении к предыдущему решению. На форме документа создается. . .
К слову об оптимизации
kumehtar 01.04.2026
Вспоминаю начало 2000-х, университет, когда я писал на Delphi. Тогда среди программистов на форумах активно обсуждали аккуратную работу с памятью: нужно было следить за переменными, вовремя. . .
Идея фильтра интернета (сервер = слой+фильтр).
Hrethgir 31.03.2026
Суть идеи заключается в том, чтобы запустить свой сервер, о чём я если честно мечтал давно и давно приобрёл книгу как это сделать. Но не было причин его запускать. Очумелые учёные напечатали на. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru