Форум программистов, компьютерный форум, киберфорум
C#: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
4 / 4 / 5
Регистрация: 22.04.2014
Сообщений: 122
MS SQL

Мобильное приложение (Android) не могу подключиться в БД MS SQL

21.10.2025, 12:29. Показов 826. Ответов 12
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброе время суток.

Помогите пожалуйста подключиться к БД MS SQL через мобильное приложение (Android).

C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
 // Создание подключения
            SqlConnection connection = new SqlConnection(connectionString);
            try
            {
                // Открываем подключение
                connection.Open();
 
                SqlDataAdapter adap = new SqlDataAdapter("select format(GETDATE(), 'dd.MM.yyyy HH:mm')", connection);
                DataTable dt = new DataTable();
                adap.Fill(dt); //Здесь выходит ошибка System.NullReferenceException: 'Object reference not set to an instance of an object'
 
 
                svajz.Text = "Подключение открыто";
            }
            catch (SqlException ex)
            {
                svajz.Text = ex.Message;
            }
Миниатюры
Мобильное приложение (Android) не могу подключиться в БД MS SQL  
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
21.10.2025, 12:29
Ответы с готовыми решениями:

Как подключиться к базе данных SQL из приложения Xamarin android
Всем привет. Мне нужна помощь с подключением к бд sql через приложение (Xamarin android) в...

Подключиться к SQL 2000. BASE_STRING = 'Driver={SQL Server};Server=(local);Database=mybase;
Пишу поключение BASE_STRING = 'Driver={SQL Server};Server=(local);Database=mybase;', тестирую...

Не могу подключиться к собственному SQL-серверу.
День добрый ! Есть : - Win 2000 SP3 - SQL 2000 SP3 На SQL создал юзера, сделал базу с табл....

12
 Аватар для Andrey-MSK
3313 / 2200 / 387
Регистрация: 14.08.2018
Сообщений: 7,404
Записей в блоге: 4
21.10.2025, 12:39
Цитата Сообщение от Ksyuhalek Посмотреть сообщение
SqlDataAdapter adap
Зачем вам устаревшая технология? Перепишите нормально - Руководство по ADO.NET и работе с базами данных в .NET Глава 1.
0
4 / 4 / 5
Регистрация: 22.04.2014
Сообщений: 122
21.10.2025, 18:11  [ТС]
Разницы от старой и новой технологии нет. Ошибка все равно остается.
Миниатюры
Мобильное приложение (Android) не могу подключиться в БД MS SQL  
0
1718 / 1455 / 165
Регистрация: 25.07.2015
Сообщений: 2,571
22.10.2025, 08:41
Цитата Сообщение от Ksyuhalek Посмотреть сообщение
Разницы от старой и новой технологии нет.
Технология одна в обоих случаях, способ загрузки данных разный. ))
По теме: соединение с БД открывается?
Что вернет connection.State после открытия соединения connection.Open() , состояние соединения ?
Опять же , если подключение уже открыто и вы попытаетесь его снова открыть ,
то вернется исключение. Я бы делал проверку перед подключением к БД.
C#
1
2
3
4
5
if(connection.State == ConnectionState.Close)
 {
   connection.Open();
  //Здесь ваш код
 }
Если подключения нет, проверяйте строку соединения.

По коду загрузки данных ошибок вроде нет.
Единственное , что для получения одной записи использовать адаптер или рейдер - ну
так себе идея. Для этого есть command.ExecuteScalar(), типа такого
C#
1
svajz.text=command.ExecuteScalar.ToString()
0
 Аватар для Andrey-MSK
3313 / 2200 / 387
Регистрация: 14.08.2018
Сообщений: 7,404
Записей в блоге: 4
22.10.2025, 08:52
Ksyuhalek, Обрамите в try .. catch, как должно быть при доступе к разделяемым ресурсам, и посмотрите где падает ваш command... Вот пример как полностью строится метод с async/await, using, параметрами, перехват ошибок. Метод сделан для вызова из внешнего кода.
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
public async Task<List<LaborHB>> GetLaborHBListAsync(Branches branch)
{
    List<LaborHB> labors = new List<LaborHB>();
    string sqlText =
        """
        SELECT
            ID_LaborHB, ID_Branch, DateHB, DecreeHB, VersionHB, NotesHB
        FROM
            dbo.tblLaborHB_00
        WHERE
            ID_Branch = @idBranch
        """;
 
    try
    {
        using (SqlConnection sqlConnection = new SqlConnection(_connectionString))
        {
            using (SqlCommand sqlCommand = new SqlCommand(sqlText, sqlConnection))
            {
                SqlParameter pBranchID = new SqlParameter
                {
                    ParameterName = "@idBranch",
                    Value = (int)branch,
                    SqlDbType = SqlDbType.Int,
                    Direction = ParameterDirection.Input
                };
                sqlCommand.Parameters.Add(pBranchID);
 
                await sqlCommand.Connection.OpenAsync();
 
                using (SqlDataReader sqlDataReader = await sqlCommand.ExecuteReaderAsync())
                {
                    if (sqlDataReader.HasRows)
                    {
                        while (await sqlDataReader.ReadAsync())
                        {
                            labors.Add(new LaborHB
                            {
                                LaborHBID = (int)sqlDataReader["ID_LaborHB"],
                                BranchID = (int)sqlDataReader["ID_Branch"],
                                DateHB = (DateTime)sqlDataReader["DateHB"],
                                DecreeHB = (string)sqlDataReader["DecreeHB"],
                                VersionHB = (int)sqlDataReader["VersionHB"],
                                NotesHB = sqlDataReader["NotesHB"]
                                    == DBNull.Value ? string.Empty : (string)sqlDataReader["NotesHB"]
                            });
                        }
                    }
                }
            }
        }
 
        return labors;
    }
    catch (SqlException sqlEx)
    {
        throw new ApplicationException(string.Format("T-SQL #{0} - {1}", sqlEx.Number, sqlEx.Message), sqlEx);
    }
    catch (Exception ex)
    {
        throw new ApplicationException(ex.Message, ex);
    }
}
Добавлено через 3 минуты
Цитата Сообщение от Kulma Посмотреть сообщение
Если подключения нет, проверяйте строку соединения.
SqlConnection кинет исключение, если со строкой что-то не так...
0
4 / 4 / 5
Регистрация: 22.04.2014
Сообщений: 122
22.10.2025, 09:05  [ТС]
Спасибо большое за помощь и отзывчивость. Но похоже, что проблема в том, что проект создан на платформе NET.Standart, а соответственно надо подключаться через API. Пошла изучать данный подход
0
1718 / 1455 / 165
Регистрация: 25.07.2015
Сообщений: 2,571
22.10.2025, 09:08
Цитата Сообщение от Andrey-MSK Посмотреть сообщение
SqlConnection кинет исключение, если со строкой что-то не так...
По идее должен, по факту не плохо бы было на нее взглянуть.
У ТС в исключение сваливается в момент обращения к набору данных, пустому набору, что в первом, что во
втором варианте.
При этом сам запрос отрабатывает нормально и по синтаксису command вроде без ошибок.
Остается только подключение.
0
 Аватар для Andrey-MSK
3313 / 2200 / 387
Регистрация: 14.08.2018
Сообщений: 7,404
Записей в блоге: 4
22.10.2025, 09:12
Цитата Сообщение от Ksyuhalek Посмотреть сообщение
Но похоже, что проблема в том, что проект создан на платформе NET.Standart
Без разницы. Проверьте что установлено из NuGet Microsoft.Data.SqlClient.
0
4 / 4 / 5
Регистрация: 22.04.2014
Сообщений: 122
22.10.2025, 09:40  [ТС]
Microsoft.Data.SqlClient - установлено.

Именно в подключении и ошибка.

Строка подключения: @"Data Source=10.1.0.125\strt;Initial Catalog=VSDP6;User ID=vesp;Password=111111"

Данная строка отлично работает в проекте для Windows, а вот для Android не работает.
Миниатюры
Мобильное приложение (Android) не могу подключиться в БД MS SQL  
0
 Аватар для IamRain
4693 / 2701 / 734
Регистрация: 02.08.2011
Сообщений: 7,228
23.10.2025, 20:51
Цитата Сообщение от Ksyuhalek Посмотреть сообщение
Данная строка отлично работает в проекте для Windows, а вот для Android не работает.
А android устройству доступен хост 10.1.0.125? Ошибка подозрительная, не должно быть NRE (по крайней мере в десктопном рантайме).
0
4 / 4 / 5
Регистрация: 22.04.2014
Сообщений: 122
28.10.2025, 09:52  [ТС]
IP с устройства Android ping уется. Предпологаю что доступ тогда есть.
0
 Аватар для Andrey-MSK
3313 / 2200 / 387
Регистрация: 14.08.2018
Сообщений: 7,404
Записей в блоге: 4
28.10.2025, 10:11
Цитата Сообщение от Ksyuhalek Посмотреть сообщение
IP с устройства Android ping уется. Предпологаю что доступ тогда есть.
Ну по IP делать доступ к серверу такое себе... Дырень в безопасности сервера СУБД будь здоров, он не должен смотреть наружу... Пишите API.
0
 Аватар для IamRain
4693 / 2701 / 734
Регистрация: 02.08.2011
Сообщений: 7,228
02.11.2025, 15:53
Цитата Сообщение от Andrey-MSK Посмотреть сообщение
Ну по IP делать доступ к серверу такое себе...
Ну что вы начали опять - дырень дырень, это частная сеть...
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
02.11.2025, 15:53
Помогаю со студенческими работами здесь

Не могу подключиться к SQL (подключение к VS)
Пытался подключиться к базе, созданной в самом VS пишет, вот что... читал что дело может быть в...

Не могу подключиться к базе данных MS SQL
Не могу подключиться к базе данных, как исправить ? con.ConnectionString = @&quot;Provider=...

Не могу подключиться к базе данных SQL Server
Всем привет. Сейчас изучаю C# по книгам и видеоурокам. На данный момент не могу подключиться к базе...

Не могу подключиться к SQL SERVER
Привет ребята, не могу подключиться к базе. Я думаю что моя проблема в том что неправильно задаю ...

Не могу подключиться к Sql Server
Помогите пожалуйста. Первый раз учусь создавать веб сервис. Создал WCF service и сталкиваюсь с...


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

Или воспользуйтесь поиском по форуму:
13
Ответ Создать тему
Новые блоги и статьи
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США. Нашел на реддите интересную статью под названием «Кто-нибудь знает, где получить бесплатный компьютер или. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru