Форум программистов, компьютерный форум, киберфорум
C# для начинающих
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.73/11: Рейтинг темы: голосов - 11, средняя оценка - 4.73
0 / 0 / 0
Регистрация: 28.08.2011
Сообщений: 8
1

Вопрос по Windows Forms

28.08.2011, 23:57. Показов 1918. Ответов 11
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Добрый вечер!
Ув. форумчане, у меня есть несколько вопросов может и простых, но меня поставивших в тупик.
Я в C# перехожу с Delphi и не знаю как реализовать следующее:

1. Как реализовать на формах обратную связь. Т.е. на одной форме я хочу получить к каким-то объектам другой формы(уже активной). К примеру как в Delphi было:
Delphi
1
2
3
4
5
6
7
unit uSecond
using uFirst;
...
procedure..
begin
   fSecond.myQuery.fieldByName...
end;
А как в C# получить какие-то данные с другой формы.

2. Как реализовать глобальное подключение к БД, что бы в любом месте приложения работать на одном подключении к БД?

Заранее спасибо за помощь!
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
28.08.2011, 23:57
Ответы с готовыми решениями:

Windows Forms
В общем мне нужно сделать примерно такое, первый пункт сделал и уперся) ошибки всякие вылазиют уже...

Windows forms
Добрый день товарищи, у меня к вам вопрос: как в приложение Windows forms убрать возможность...

Windows Forms
Дали написать курсовую роботу по теме "методы шифрования текстов". Нужно создать программу...

Windows Forms C#
Идея: Сделать програмку Вопрос: Создаём рандомное трёхзначное число. Юзер вводит в текстбокс...

11
24 / 24 / 4
Регистрация: 07.02.2011
Сообщений: 163
29.08.2011, 00:13 2
Ответ на первый вопрос найдете здесь:
Ответы на 7 самых частых вопросов по WinForms

Пункт 2.
1
0 / 0 / 0
Регистрация: 28.08.2011
Сообщений: 8
29.08.2011, 00:20  [ТС] 3
С формами я разобрался - спасибо!
Но вопрос по БД остался открытым.. Как сделать одно глобальное подключение, а потом обращаться к нему везде, где мне надо в приложении?
0
24 / 24 / 4
Регистрация: 07.02.2011
Сообщений: 163
29.08.2011, 00:38 4
Цитата Сообщение от Dimkin Посмотреть сообщение
С формами я разобрался - спасибо!
Но вопрос по БД остался открытым.. Как сделать одно глобальное подключение, а потом обращаться к нему везде, где мне надо в приложении?
Может реализовать его в отдельном классе например, затем подключить через using "имя вашего namespace"; (без кавычек), а потом объявить его в классе формы и получать доступ из любого места в этом классе формы?
Не особо силен в этих вещах, так что строго не судите
0
0 / 0 / 0
Регистрация: 28.08.2011
Сообщений: 8
29.08.2011, 00:49  [ТС] 5
Цитата Сообщение от Shue Посмотреть сообщение
Может реализовать его в отдельном классе например, затем подключить через using "имя вашего namespace"; (без кавычек), а потом объявить его в классе формы и получать доступ из любого места в этом классе формы?
Не особо силен в этих вещах, так что строго не судите
Если объявить - это создать объект класса, где будет подключение, то я об этом сразу подумал, но! При таком варианте у меня будет всё равно отдельное подключение для каждой формы, а мне бы хотелось одно подключение для всего приложения.
0
167 / 96 / 23
Регистрация: 13.03.2011
Сообщений: 402
29.08.2011, 04:40 6
Радражает c# - на ocaml перешел
0
0 / 0 / 0
Регистрация: 28.08.2011
Сообщений: 8
29.08.2011, 07:33  [ТС] 7
Так кто-нить знает как создать одно подключение к БД для всего многооконного приложения?
Подскажите плиз!!!
0
23 / 20 / 3
Регистрация: 12.08.2010
Сообщений: 206
29.08.2011, 09:16 8
Dimkin, сомнительная штука, в смысле целесообразности, ну да бывает всякое.
Попробуйте создать паблик-статик класс, который уже в конструкторе подключится куда нужно.
Но тут такая штука, что при задании нового sql запроса, например, Вам все-равно придется написать нечто похожее:
C#
1
2
3
4
using (SqlCommand cmd = new SqlCommand("запрос", "строка подключения")
{
    cmd.ExecuteNonQuery();
}
Т.е. фактически, каждый новый запрос, требует подключения к БД, ну и отключения. =)
По крайней мере, у меня вот такая информация в голове. Вполне вероятно, что я чего-то не знаю.

Есть еще автономный уровень. Он вообще подразумевает одно подключение для взятия информации, а потом только для внесения изменений. (копать в сторону DataSet, DataTable, DataAdapter и т.д.)
1
334 / 270 / 18
Регистрация: 19.01.2011
Сообщений: 597
29.08.2011, 09:44 9
Сделайте публичную переменную в Вашем namespace приложения. При загрузке инициализируйте (открывайте соединение с бд, еще чего там...) - а дальше используйте его. Еще один путь - в конструкторе формы иметь параметр - указатель на источник данных (Ваш connection или еще какой то объект связи с данными) - и в форме использовать его, а при создании формы передавать в конструктор ранее созданный объект. При использовании типизированных датасетов оба подхода подойдут (первый проще к реализации).
1
0 / 0 / 0
Регистрация: 28.08.2011
Сообщений: 8
29.08.2011, 11:03  [ТС] 10
Ясно, спасибо - буду думать дальше!

А можно ещё вопрос.. Я наткнулся на такую возможность студии: в Меню "Данные->Показать источники данных" можно добавить источник данных и указать свою БД. Потом добавление отображения данных на форму осуществляется одним перетаскивание таблицы из источника.
Кажется очень просто, но я не пойму как работает этот источник: Работает ли с одним подключением, как обновлять данные в нём и как вообще с ним работать? (может кто знает где почитать на эту тему - киньте ссылку, буду очень благодарен)

В большом многооконном проекте лучше работать через этот источник данных или писать подключения и всё остальное вручную?
0
23 / 20 / 3
Регистрация: 12.08.2010
Сообщений: 206
29.08.2011, 11:49 11
Вы говорите как раз о автономном уровне подключения:
Вот здесь можно почитать, например.

В большом многооконном проекте лучше работать через этот источник данных или писать подключения и всё остальное вручную?
Дело скорее привычки.
Я попробовал все, в разрезе моих текущих задач. В итоге остановился на комбинированном стиле:

1) Получение данных в DataTable
2) Обработка на локальном уровне
3) Запись - прямым подключением.

Очень понравился EntityFramework в связке с LINQ. Но EF оказался очень прихотлив к архитектуре БД.
1
0 / 0 / 0
Регистрация: 28.08.2011
Сообщений: 8
29.08.2011, 14:20  [ТС] 12
Цитата Сообщение от half-node Посмотреть сообщение
Вы говорите как раз о автономном уровне подключения:
Вот здесь можно почитать, например.


Дело скорее привычки.
Я попробовал все, в разрезе моих текущих задач. В итоге остановился на комбинированном стиле:

1) Получение данных в DataTable
2) Обработка на локальном уровне
3) Запись - прямым подключением.

Очень понравился EntityFramework в связке с LINQ. Но EF оказался очень прихотлив к архитектуре БД.
О! Спасибо огромное. Как раз то, что надо. Буду пробовать!
0
29.08.2011, 14:20
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
29.08.2011, 14:20
Помогаю со студенческими работами здесь

Консоль в windows forms
Всем привет. Подскажите как решить задачку. В приложении windows forms пытаюсь чтобы при нажатии...

Потоки и Windows Forms
Здравстуйте, помогите разобраться с потоками в них я 0 лаб по программухе не было в книге не оч...

Стрелки в Windows Forms
Нарисовать стрелки (с помощью мыши), соединяющие две строки находящиеся в разных блоках.

Windows Forms баг?
На 1й картинке - что выходит если менять свойста строки на "visible=true" и "locked=false" с...


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

Или воспользуйтесь поиском по форуму:
12
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru