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

Как в Visual studio сделать запрос на вход от лица другого пользователя

07.11.2021, 02:44. Показов 1869. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Вопрос такой, я хочу зайти в свою базу даных от другого пользователя, и в зависимости какую роль имеет пользователь ему открывается другая форма, решил использовать стандартный запрос execute as user = 'username', но проверку он все равно делает от лица суперпользователя, как мне записать запрос в C# чтобы зайти от лица пользователя и проверка проводилась от его лица.
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
64
65
66
namespace Поликлиника
{
    public partial class LoginForm : Form
    {
        private SqlConnection sqlConnection = null;
 
        public LoginForm()
        {
            InitializeComponent();
        }
 
        private void LoginForm_Load(object sender, EventArgs e)
        {
            sqlConnection = new SqlConnection(ConfigurationManager.ConnectionStrings["Poliklinika"].ConnectionString);
            sqlConnection.Open();
            if (sqlConnection.State == ConnectionState.Open)
            {
                MessageBox.Show("Подключение установлено!");
            }
        }
 
        private void ButtonLogin_Click(object sender, EventArgs e)
        {
            SqlDataAdapter User = new SqlDataAdapter("SELECT COUNT (*) FROM Users where login='" + LoginField.Text + "' and password='"+PasswordField.Text+"'", sqlConnection);
            
            DataTable tableUser = new DataTable();
            User.Fill(tableUser);
            if(tableUser.Rows[0][0].ToString() == "1")     
            {
                
                SqlCommand command = new SqlCommand($"execute as user='{LoginField.Text}'", sqlConnection);              
                User = new SqlDataAdapter("if (Is_member(N'Работники_регистратуры')=1) if (Is_member(N'Администратор_регистратуры') = 1) select 1;  else select 2;   else if (Is_member(N'Врачи') = 1) select 3;   else select 4; ", sqlConnection);
                tableUser.Clear();
                User.Fill(tableUser);
                if (tableUser.Rows[0][0].ToString() == "1")
                {
                    this.Hide();
                    Form1 f = new Form1();
                    f.Show();
                }
                if (tableUser.Rows[0][0].ToString() == "2")
                {
                    this.Hide();
                    Form2 f = new Form2();
                    f.Show();
                }
                if (tableUser.Rows[0][0].ToString() == "3")
                {
                    this.Hide();
                    Form3 f = new Form3();
                    f.Show();
                }
                if (tableUser.Rows[0][0].ToString() == "4")
                {
                    this.Hide();
                    Form4 f = new Form4();
                    f.Show();
                }
            }
            else
            {
                MessageBox.Show("Пожалуйста введите логин или пароль");
            }  
        }
    }
}
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
07.11.2021, 02:44
Ответы с готовыми решениями:

Как в Visual studio сделать запрос на вход от лица другого пользователя
Вопрос такой, я хочу зайти в свою базу даных от другого пользователя, и в зависимости какую роль имеет пользователь ему открывается другая...

Visual studio 2013: попытка подключения от имени другого пользователя
visual studio 2013 ошибка в проге при смене пользователя.

Как сделать запрос к БД в Visual Studio 2010
Доброго всем времени суток у меня такой вопрос касающийся VS 2010 я хочу сделать простой запрос в VS и не соображу как =)) вот скрин...

2
 Аватар для Andrey-MSK
3320 / 2207 / 387
Регистрация: 14.08.2018
Сообщений: 7,431
Записей в блоге: 4
07.11.2021, 05:28
Лучший ответ Сообщение было отмечено Zulan1997 как решение

Решение

Цитата Сообщение от Zulan1997 Посмотреть сообщение
как мне записать запрос в C# чтобы зайти от лица пользователя и проверка проводилась от его лица.
Настроить сервер на аутентификацию SQL, создать на сервере пользователей с определёнными правами, в строку подключения передавать не Integrated Security, а логин с паролем из окна входа. И тогда уже всё будет производиться от имени пользователя БД, который в неё вошел.
Строка подключения будет примерно такой
Code
1
Server=myServerAddress;Database=myDataBase;User Id=myUsername;Password=myPassword;
ConnectionStrings MSSQL - выбирайте подходящую.

Добавлено через 5 минут
И это, используйте параметры в запросах...
0
0 / 0 / 0
Регистрация: 14.03.2020
Сообщений: 28
07.11.2021, 15:47  [ТС]
Спасибо выручил
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
07.11.2021, 15:47
Помогаю со студенческими работами здесь

Как сделать запрос с параметром к базе данных SQL в Visual Studio 2019?
Добрый день! Подскажите пожалуйста, как сделать запрос с параметром к базе данных SQL в Visual studio 2019 ? Книг по новым версиям...

Как сделать вход на сайт пользователя и админа?
скажем у меня есть форма входи ) ну там 2 textBox и кнопка, вводишь логин и пароль и заходишь на сайт и когда переходишь по другим...

Как сделать вход и регистрацию для пользователя c сохранение данных в access
как сделать вход и регистрацию для пользователя c сохранение данных в acces ?

Как изменить запрос в конструкторе запросов Visual Studio?
Visual Studio 2015 MS Sql - 2014 Разместил на форме "dataGridView". Подключил источник данных. Создал запрос. Вопрос. Где...

Как сделать так, чтобы если выбрал одного пользователя была видна кнопка, а если другого пользователя не видна
Как сделать так, чтобы если выбрал одного пользователя была видна кнопка, а если другого пользователя не видна.


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru