Форум программистов, компьютерный форум, киберфорум
Наши страницы
C#: Базы данных, ADO.NET
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.50/4: Рейтинг темы: голосов - 4, средняя оценка - 4.50
Женя_Муравьев
0 / 0 / 0
Регистрация: 10.04.2014
Сообщений: 5
1

Поиск по базе данных MS SQL Server не получается

14.04.2014, 02:26. Просмотров 753. Ответов 5
Метки нет (Все метки)

Пишу учебную программу для работы с базой данных MS Sql Server. До этого дело с базами данных вообще не имел. В идеале программа будет представлять некое хранилище музыкальных файлов. Сейчас она полностью еще сырая. написал только добавление альбомов, исполнителей и названия самих треков. Дошло дело до поиска.

Пример поиска выкладываю.

C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
  #region поиск по исполнителю
        private void button6_Click(object sender, EventArgs e)
        {
            
            dataset.Clear();
            SqlConnection connection = CreateConnection();
            string artist = comboBox4.Text.ToString();
            CDadapter = new SqlDataAdapter("SELECT CD.ID, CD.Album, CD.Date, Artist.ArtName, Genre.GenreDesript FROM CD INNER JOIN Artist ON CD.artID = Artist.ArtID INNER JOIN Genre ON CD.genreID = Genre.GenreID WHERE  Artist.ArtName LIKE  '" + artist + "%'", connection);
            CDadapter.Fill(dataset, "CD");
            //Tracksadapter.Fill(dataset, "Tracks");
            Artadapter.Fill(dataset, "Artist");
           
            gridCD.Update();
            
            connection.Close();
        }
        #endregion
если снять комментирование с //Tracksadapter.Fill(dataset, "Tracks"); то будет ругаться : "Не удалось включить ограничения. По меньшей мере одна строка содержит значение, нарушающее ограничения по отсутствию пустых значений, уникальности или внешним ключам." А без него все, в принципе, работает, исполнителей отбирает, но смысла-то уже нет. На форме два связанных datagridview(CD-треки), связаны они по примеру из FAQ, поэтому, если не заполнять таблицу треки, то цель создания БД теряется. Найти, в чем проблема, не смог. Прошу помощи. Файл проекта тоже приложил. и да, опыт программирования у меня такой же, как и опыт работы с БД. Но хочется научиться.
0
Вложения
Тип файла: 7z BD.7z (1.81 Мб, 14 просмотров)
Лучшие ответы (1)
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
14.04.2014, 02:26
Ответы с готовыми решениями:

Не получается подключится к базе MS SQL Server через VIsual Studio 2012
Здравствуйте, я создал новый проект, пытаюсь в нём создать модель Entity Framework. Когда создаю...

Поиск в базе SQL Server по нескольким параметрам
Имеется форма поиска. в ней можно осуществлять поиск только по одному параметру. как сделать,...

Не подключается к базе данных (sql server 2005)
Не подключается к базе данных using System; using System.Collections.Generic; using...

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

Многопоточный доступ к базе данных sql server
Доброго вечера. Возникла проблема при обращении к базе. Гугл по этому поводу молчит. Может кто-то...

5
Женя_Муравьев
0 / 0 / 0
Регистрация: 10.04.2014
Сообщений: 5
14.04.2014, 02:40  [ТС] 2
Помогите, пожалуйста, не знаю, как перенести тему из .NET 3.x в .NET 4.x.
0
some_name
Вежливость-главное оружие
228 / 228 / 86
Регистрация: 19.02.2013
Сообщений: 1,441
14.04.2014, 03:31 3
Попробуйте провертить, правильно ли настроены отношения между таблицами.
Через MS SqlServer. Протистируйте на запросах, которые используете в программе.
1
Женя_Муравьев
0 / 0 / 0
Регистрация: 10.04.2014
Сообщений: 5
14.04.2014, 03:43  [ТС] 4
Настроено, кажется, все правильно. Во всяком случае так, как мне и нужно. При выборе элемента из одной таблицы мы получаем список элементов ему соответствующих из другой таблицы. Но, может быть, я не правильно вас понял.
0
some_name
Вежливость-главное оружие
228 / 228 / 86
Регистрация: 19.02.2013
Сообщений: 1,441
14.04.2014, 04:36 5
Лучший ответ Сообщение было отмечено Женя_Муравьев как решение

Решение

Попробуйте запросы, которые вы используете в программе, создать в MS SqlServer и там выполнить.
Если все ок, тогда проблема именно в программной реализации.
1
Женя_Муравьев
0 / 0 / 0
Регистрация: 10.04.2014
Сообщений: 5
14.04.2014, 20:31  [ТС] 6
Значит, проблема в программной реализации. Посмотрите, пожалуйста, код и скажите куда мне копать

Добавлено через 26 секунд
Все, все получилось, действительно, проблема была в запросах) Спасибо
0
14.04.2014, 20:31
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
14.04.2014, 20:31

Доступ к базе данных SQL Server из интернет
Есть база данных SQL Server, есть программа наполняющая ее, есть программа работающая с этой БД -...

Как подключиться к базе данных MS SQL Server 2008 и сделать выгрузку?
Всем привет) Как подключиться к базе данных MS SQL Server 2008 и сделать выгрузку? Создаю Windows...

Не получается обновить данные в БД SQL Server при изменении данных в dataGridView
ADO.NET C# Добавлено через 2 минуты using System; using System.Collections.Generic; using...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2019, vBulletin Solutions, Inc.
Рейтинг@Mail.ru