Форум программистов, компьютерный форум, киберфорум
C# Windows Forms
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.71/7: Рейтинг темы: голосов - 7, средняя оценка - 4.71
0 / 0 / 0
Регистрация: 10.06.2016
Сообщений: 35

Incorrect syntax near the keyword 'WHERE'

21.12.2017, 19:55. Показов 1624. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
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
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
        }
        int kodOkv;
        private void button2_Click(object sender, EventArgs e)
        {
            OkvedName oName = new OkvedName();
            if (oName.ShowDialog() != DialogResult.OK)
            {
                textBox3.Text = "";
                return;
            }
            else
            {
                kodOkv = oName.okvKod;
                textBox3.Text = oName.okvName;
            }
        }
        string sql;
        private void Form1_Load(object sender, EventArgs e)
        {
            sql = @"SELECT        UL.IdUL, UL.Ogrn, UL.Inn, UL.Kpp, Licenz.NumLic, Licenz.DtResh, Licenz.LicOrg, Licenz.VidLic, Licenz.SostLic, Licenz.DtStart, Licenz.DtEnd, 
                         Licenz.DtStop, Licenz.StStartNow, VidLic.vlName
FROM            UL INNER JOIN
                         Licenz ON UL.IdUL= Licenz.IdUL INNER JOIN
                         VidLic ON Licenz.VidLic = VidLic.IdVidLic;";
        }
 
        private void button1_Click(object sender, EventArgs e)
        {
            string f = "";
            string mesOgrn = "", mesInn = "";
            if (textBox1.Text != "")
            {
                mesOgrn = testOgrn(textBox1.Text);
                if (mesOgrn != "")
                    MessageBox.Show(mesOgrn);
                    else 
                f += "(Ogrn = '" + textBox1.Text + "') AND";
           }
            if (textBox2.Text!="")
            {
                mesInn = testInn(textBox2.Text);
                if (mesInn != "")
                    MessageBox.Show(mesInn);
                else
            
                f+= "(Inn '" + textBox2.Text + "')AND ";
}
            if (textBox3.Text != "")
                f += "(IdVidLic.vlName = '" + textBox3.Text + "') AND";
            if(f!="")
                f = "\nWHERE"+ f.Remove (f.Length - 5);
            BindingSource bs = new BindingSource();
            sqlCommand1.CommandText = sql + f;
            sqlConnection1.Open();
            SqlDataReader dr = sqlCommand1.ExecuteReader();
            if (dr.HasRows)
                bs.DataSource = dr;
            dr.Close();
            sqlConnection1.Close();
            //dataGridView1.AutoGenerateColumns = false;
            dataGridView1.DataSource = bs; 
           
        }
        private bool isClipher(string s)
        {
            for (int i = 0; i < s.Length; i++)
            {
                if (!char.IsDigit(s[i]))
                    return false;
            }
            return true;
        }
        private string testOgrn (string s)
        {
            if (s.Length != 13)
                return "Длина ОГРН не равна 13;";
            if (!isClipher(s))
                return "В коде ОГРН нецифровая информация";
            return "";
        }
        private string testInn(string s)
        {
            if (s.Length != 10)
                return "Длина ИНН не равна 10";
            if (!isClipher(s))
                return "В коде ИНН нецифровая информация";
            return "";
        }
    }
}
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
21.12.2017, 19:55
Ответы с готовыми решениями:

Incorrect syntax near the keyword 'Values'
Здравствуйте, не пойму почему возникает ошибка incorrect syntax near the keyword 'Values' при обработке запроса на добавление в таблицу БД....

Появилась ошибка в запросе - Incorrect syntax near the keyword 'Table'
Объясните пожалуйста: выходит ошибка в этом месте, не знаю, почему sel.Fill(dt); -Incorrect syntax near the keyword 'Table' private void...

"Incorrect syntax near the keyword 'Table'."
здравствуйте! задача сделать бд с добавлением, обновлением, удалением, поиском и команды написаны, но с кучей ошибок одна из них:...

1
3357 / 1776 / 83
Регистрация: 05.08.2010
Сообщений: 4,471
21.12.2017, 22:16
Так у Вас тут полная Ж, товарищ!
Если есть нужда по нескольким критериям фильтровать данные, то необходимо собирать строку нормально.
У Вас неверно собрана строка.

Добавлено через 23 минуты
Если верно понял Ваши дебри, то:

C#
1
sql = @"SELECT UL.IdUL, UL.Ogrn, UL.Inn, UL.Kpp, Licenz.NumLic, Licenz.DtResh, Licenz.LicOrg, Licenz.VidLic, Licenz.SostLic, Licenz.DtStart, Licenz.DtEnd, Licenz.DtStop, Licenz.StStartNow, VidLic.vlName FROM UL INNER JOIN Licenz ON UL.IdUL = Licenz.IdUL INNER JOIN VidLic ON Licenz.VidLic = VidLic.IdVidLic ";
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
string f = " WHERE 1=1 ";
string mesOgrn = "", mesInn = "";
if (textBox1.Text != "") {
    mesOgrn = testOgrn(textBox1.Text);
    if (mesOgrn != "")
        MessageBox.Show(mesOgrn);
    else
        f += " AND (Ogrn = '" + textBox1.Text + "')";
}
if (textBox2.Text!="") {
    mesInn = testInn(textBox2.Text);
    if (mesInn != "")
        MessageBox.Show(mesInn);
    else
        f+= " AND (Inn '" + textBox2.Text + "')";
}
if (textBox3.Text != "")
    f += " AND (IdVidLic.vlName = '" + textBox3.Text + "')";
 
BindingSource bs = new BindingSource();
sqlCommand1.CommandText = sql + f;
sqlConnection1.Open();
SqlDataReader dr = sqlCommand1.ExecuteReader();
if (dr.HasRows)
    bs.DataSource = dr;
dr.Close();
sqlConnection1.Close();
dataGridView1.DataSource = bs;
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
21.12.2017, 22:16
Помогаю со студенческими работами здесь

Incorrect syntax near
Всем доброго времени суток. Пытаюсь с помощью запроса в MS SQL Server заполнить таблицу : use Lessons go delete from choses1 ...

Incorrect syntax near
Подскажите пожалуйста, мне нужно взять дату с одного DateTimePicker'a, время с другого и поместить их в один столбец (типа DateTime) БД MS...

Incorrect syntax near '='
Помогите пожалуйста что это за ошибка: Incorrect syntax near '=': private void comboBox5_SelectedValueChanged(object sender, EventArgs e)...

Incorrect syntax near ','
Доброго времени суток! Может кто подскажет причину неработающей кнопочки у меня на форме вот собственно код ее: procedure...

Ошибка: Incorrect syntax near '('
Добрый вечер. Есть Форма, на форме кнопка Search. При нажатии на кнопку вызывается хранимая процедура Stored_Proc и загружает...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Сумматор с применением элементов трёх состояний.
Hrethgir 26.03.2026
Тут. https:/ / fips. ru/ EGD/ ab3c85c8-836d-4866-871b-c2f0c5d77fbc Первый документ красиво выглядит, но без схемы. Это конечно не даёт никаких плюсов автору, но тем не менее. . . всё может быть. . .
Автозаполнение реквизитов при создании документа
Maks 26.03.2026
Программный код из решения ниже размещается в модуле объекта документа, в процедуре "ПриСозданииНаСервере". Алгоритм проверки заполнения реализован для исключения перезаписи значения реквизита,. . .
Команды "Заполнить" и "Очистить" на форме документа
Maks 26.03.2026
1. Команда формы "ЗаполнитьЗапчасти". На примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. В качестве источника данных выбран регистр накопления, в. . .
Кому нужен AOT?
DevAlt 26.03.2026
Решил сделать простой ланчер Написал заготовку: dotnet new console --aot -o UrlHandler var items = args. Split(":"); var tag = items; var id = items; var executable = args;. . .
Отправка уведомления на почту при изменении наименования справочника
Maks 24.03.2026
Программная отправка письма электронной почты на примере изменения наименования типового справочника "Склады" в конфигурации БП3. Перед реализацией необходимо выполнить настройку системной учетной. . .
модель ЗдравоСохранения 5. Меньше увольнений- больше дохода!
anaschu 24.03.2026
Теперь система здравосохранения уменьшает количество увольнений. 9TO2GP2bpX4 a42b81fb172ffc12ca589c7898261ccb/ https:/ / rutube. ru/ video/ a42b81fb172ffc12ca589c7898261ccb/ Слева синяя линия -. . .
Midnight Chicago Blues
kumehtar 24.03.2026
Такой Midnight Chicago Blues, знаешь?. . Когда вечерние улицы становятся ночными, а ты не можешь уснуть. Ты идёшь в любимый старый бар, и бармен наливает тебе виски. Ты смотришь на пролетающие. . .
SDL3 для Desktop (MinGW): Вывод текста со шрифтом TTF с помощью библиотеки SDL3_ttf на Си и C++
8Observer8 24.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-text-sdl3-c. zip finish-text-sdl3-cpp. zip
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru