No, no, no.
These answers are all wrong. There is a fundamental absence of knowledge in your brain that I’m going to remedy right now.
Your major issue here is your naming scheme. It’s verbose, contains undesirable characters, and is horribly inconsistent.
First: A table that is called Salesperson
does not need to have each field in the table called Salesperson.Salesperson number
, Salesperson.Salesperson email
. You’re already in the table Salesperson
. Everything in this table relates to Salesperson
. You don’t have to keep saying it.
Instead use ID
, Email
. Don’t use Number
because that’s probably a reserved word. Do you really endeavour to type [] around every field name for the lifespan of your database?
Primary keys on a table called Student
can either be ID
or StudentID
but be consistent. Foreign keys should only be named by the table it points to followed by ID
. For example: Student.ID
and Appointment.StudentID
. ID
is always capitalized. I don’t care if your IDE tells you not to because everywhere but your IDE will be ID
. Even Access likes ID
.
Second: Name all your fields without spaces or special characters and keep them as short as possible and if they conflict with a reserved word, find another word.
Instead of: phone number
use PhoneNumber
or even better, simply, Phone
. If you choose what time user made the withdrawal
, you’re going to have to type that in every single time.
Third: And this one is the most important one: Always be consistent in whatever naming scheme you choose. You should be able to say, «I need the postal code from that table; its name is going to be PostalCode.» You should know that without even having to look it up because you were consistent in your naming convention.
Recap: Terse, not verbose. Keep names short with no spaces, don’t repeat the table name, don’t use reserved words, and capitalize each word. Above all, be consistent.
I hope you take my advice. This is the right way to do it. My answer is the right one. You should be extremely pedantic with your naming scheme to the point of absolute obsession for the rest of your lives on this planet.
NOTE:You actually have to change the field name in the design view of the table and in the query.
Регистрация на форуме тут, о проблемах пишите сюда — alarforum@yandex.ru, проверяйте папку спам! Обязательно пройдите восстановить пароль
Поиск по форуму |
Расширенный поиск |
Страница 1 из 2 | 1 | 2 | Следующая > |
Почему возникает эта ошибка.
Ошибка синтаксиса (пропущен оператор) в выражении запроса ‘[Стипендія нарахування].[Середній бал]? (база данных в Access 2010)
SELECT [Стипендія нарахування].[Середній бал]
IF([Середній бал]<4,»0″,
IF([Середній бал]=5,»950″,
IF([Середній бал]>=4 And <5,»800″)) AS [Стипендія]
FROM [Стипендія нарахування];
Сообщение об ошибке при использовании специальных символов в базах данных Access
В этой статье перечислены специальные символы, которые не следует использовать при работе с именами объектов базы данных или именами полей во всех версиях Access.
Оригинальный номер базы знаний: 826763
Эта статья применима к файлам баз данных Microsoft Access (.mdb) или (.accdb), а также к файлу проекта Microsoft Access (.adp).
Симптомы
При использовании специальных символов в Access возникает одна из следующих проблем.
Проблема 1
В имени поля таблицы используется один из следующих специальных символов:
- Знак над символом (`)
- Восклицательный знак (!)
- Точка (.)
- квадратные скобки ([])
- Пробел
- Непечатаемые символы
В этом случае отобразится следующее сообщение об ошибке:
Недопустимое имя поля.
Убедитесь, что имя не содержит точку (.), восклицательный знак(!), квадратные скобки ([]), пробел или непечатаемый символ, например символ возврата каретки. Если вы вставляете имя из другого приложения, попробуйте нажать клавишу ESC и ввести имя еще раз.
При использовании этих специальных символов в имени таблицы отобразится следующее сообщение об ошибке:
Введенное имя объекта ‘TableName‘ не соответствует правилам именования объектов Microsoft Office Access.
Проблема 2
Вы создаете выражение запроса. Выражение запроса включает поля, содержащие специальные символы. При использовании отдельных специальных символов отображается следующее сообщение об ошибке:
Если имя поля содержит пробел, вопросительный знак (?) или знак @, отобразится следующее сообщение об ошибке:
Ошибка синтаксиса во введенном выражении.
Задано значение для операции без оператора
Если имя поля содержит кавычки («) или апостроф (‘), отобразится следующее сообщение об ошибке:
Введенное выражение содержит ошибочную строку.
Строка может содержать до 2048 знаков, включая знаки открывающей и закрывающей кавычек.
Если имя поля содержит знак решетки (#), отобразится следующее сообщение об ошибке:
Введенное выражение содержит недопустимое значение даты.
Если имя поля содержит знак процента (%), тильду (
), точку с запятой (;) или скобки ([]), отобразится следующее сообщение об ошибке:
Ошибка синтаксиса во введенном выражении.
Пропущен операнд или оператор, введен недопустимый знак или лишняя запятая, либо задана строка без кавычек.
Если имя поля содержит фигурные скобки (), отобразится следующее сообщение об ошибке:
Неверно сформированный код GUID в выражении запроса ‘ObjectName‘
Если имя поля содержит квадратные скобки ([]) или круглые скобки (()), отобразится следующее сообщение об ошибке:
Во введенном выражении отсутствует закрывающая скобка, квадратная скобка (]) или вертикальная черта (|).
Проблема 3
У вас есть запрос, содержащий выражения запроса. Выражения запроса включают поля, содержащие специальные символы. При выполнении запроса предлагается ввести значение параметра. Как правило, эта проблема возникает при использовании следующих специальных символов:
- знак «больше» (>);
- знак «меньше» (<);
- Точка (.)
- Звездочка (*)
- Двоеточие (:)
- Крышка (^)
- Знак плюс (+)
- Обратная косая черта ()
- Знак равенства (=)
- амперсанд (&);
- Косая черта (/)
Обходной путь
Чтобы устранить эту проблему, не используйте специальные символы. Если в выражениях запроса необходимо использовать специальные символы, заключите их в квадратные скобки ([]). Например, если вы хотите использовать знак «больше» (>), используйте [>].
Дополнительная информация
Microsoft Access не ограничивает использование специальных символов, таких как знак решетки (#), точка (.) или кавычки («) в именах объектов базы данных или в именах полей базы данных. Однако при использовании специальных символов могут возникнуть непредвиденные ошибки. Поэтому корпорация Майкрософт рекомендует не использовать специальные символы в именах объектов базы данных в базе данных Access или в проекте базы данных. В этой статье рассматриваются специальные символы, которые не следует использовать во избежание известных проблем с ними.
При работе с Access или другим приложением, например приложением Microsoft Visual Basic или приложением Active Server Pages (ASP), не следует использовать следующие специальные символы:
Соглашения об именовании в Access
Корпорация Майкрософт рекомендует не использовать точку (.), восклицательный знак (!), знак ударения (`), квадратные скобки ([ ]), пробел ( ) или кавычки («) внутри имен функций, имен переменных, имен полей или имен объектов базы данных, таких как таблицы и формы.
Использование следующих специальных символов в Access приводит к возникновению известных проблем. В следующих сценариях описано, когда не следует использовать специальные символы:
Что значит пропущен оператор в выражении запроса access
Профиль
Группа: Участник
Сообщений: 310
Регистрация: 15.11.2007
Репутация: нет
Всего: нет
Здравствуйте.
Вобще на форме выбирется ДАТА в dateTimePicker, затем хочу сделать ЗАПРОС на ВЫБОРКУ из таблицы (Access) по этой дате . ну если дата совпала, то потом все вывожу в dataGridView1
Код |
OleDbDataAdapter B = new OleDbDataAdapter(«SELECT * FROM Содержание_заказа WHERE Дата=»+dateTimePicker1.Value+»», «Provider=Microsoft.Jet.OLEDB.4.0;» + «Data Source=» + @»….kafe.mdb»); B.SelectCommand.Connection.Open(); B.SelectCommand.ExecuteNonQuery(); B.SelectCommand.Connection.Close(); DataTable C = new DataTable(); B.Fill(C); dataGridView1.DataSource = C; |
ну вобщем когда я на форме выбираю дату и нажимаю кнопку поиск ВЫЛАЗИЕТ вот такая ОШИБКА:
Код |
Ошибка синтаксиса (пропущен оператор) в выражении запроса ‘Дата=03.12.2008 0:00:00’. |
Код |
SELECT * FROM Содержание_заказа WHERE Дата=03.12.2008 0:00:00 |
Помогите разобраться с этой проблемой.
Заранее спасибо.
Let’s do some .NET
Профиль
Группа: Модератор
Сообщений: 2828
Регистрация: 19.12.2005
Где: Санкт-Петербург
Репутация: нет
Всего: 67
kuller, dateTimePicker1.Value.ToString(«dd.MM.yyyy»);
Добавлено через 36 секунд
kuller, а вообще в каком формате дата хранится в базе?
Профиль
Группа: Участник
Сообщений: 310
Регистрация: 15.11.2007
Репутация: нет
Всего: нет
Let’s do some .NET
Профиль
Группа: Модератор
Сообщений: 2828
Регистрация: 19.12.2005
Где: Санкт-Петербург
Репутация: нет
Всего: 67
Вот так выглядит у меня в Access 2003 запрос на выборку поля с датой
SELECT Table1.ID, Table1.Field1
FROM Table1
WHERE (((Table1.Field1)=#1/10/2008#));
Профиль
Группа: Участник
Сообщений: 310
Регистрация: 15.11.2007
Репутация: нет
Всего: нет
Код |
Дата содержит синтаксическую ошибку в выражении запроса ‘Дата=#03.12.2008 0:00:00#’. |
Код |
SELECT * FROM Содержание_заказа WHERE Дата=#03.12.2008 0:00:00# |
Добавлено через 4 минуты и 4 секунды
и так ошибка(((
Код |
OleDbDataAdapter B = new OleDbDataAdapter(«SELECT * FROM Содержание_заказа WHERE (([Содержание_заказа].[Дата]=» + dateTimePicker1.Value + «))», «Provider=Microsoft.Jet.OLEDB.4.0;» + «Data Source=» + @»….kafe.mdb»); |
Код |
Ошибка синтаксиса (пропущен оператор) в выражении запроса ‘(([Содержание_заказа].[Дата]=03.12.2008 0:00:00))’. |
Let’s do some .NET
Профиль
Группа: Модератор
Сообщений: 2828
Регистрация: 19.12.2005
Где: Санкт-Петербург
Репутация: нет
Всего: 67
kuller, попробуйте прогнать запрос с хардкодом
Код |
OleDbDataAdapter B = new OleDbDataAdapter(«SELECT * FROM Содержание_заказа WHERE Дата= #12/03/2008#», «Provider=Microsoft.Jet.OLEDB.4.0;» + «Data Source=» + @»….kafe.mdb»); B.SelectCommand.Connection.Open(); B.SelectCommand.ExecuteNonQuery(); B.SelectCommand.Connection.Close(); DataTable C = new DataTable(); B.Fill(C); dataGridView1.DataSource = C; |
Профиль
Группа: Участник
Сообщений: 310
Регистрация: 15.11.2007
Репутация: нет
Всего: нет
Код |
OleDbDataAdapter B = new OleDbDataAdapter(«SELECT * FROM Содержание_заказа WHERE Дата=#12/03/2008#», . |
ну т.к. в БД нет строки с такой датой то у меня выскочила табличка:
Код |
MessageBox.Show(«Извените, по вашему запросу ничего не найдено», . |
значит все работает, но это для статического варианта даты . а вот как теперь это исправить для динамически меняющейся даты.
Добавлено через 1 минуту и 8 секунд
Вот поставил 20/11/2008:
и в dataGridView1 вывелись ВСЕ найденные РЕЗУЛЬТАТЫ .. причем верные)))))
Добавлено через 3 минуты и 34 секунды
ВЫВОД:
дату надо получить из dateTimePicker1.Value и привести к виду:
#ч/м/г#,а потом только вызывать запрос.
Let’s do some .NET
Профиль
Группа: Модератор
Сообщений: 2828
Регистрация: 19.12.2005
Где: Санкт-Петербург
Репутация: нет
Всего: 67
Код |
OleDbDataAdapter B = new OleDbDataAdapter(«SELECT * FROM Содержание_заказа WHERE Дата=#»+dateTimePicker1.Value.ToString(«dd/MM/yyyy»)+»#», «Provider=Microsoft.Jet.OLEDB.4.0;» + «Data Source=» + @»….kafe.mdb»); B.SelectCommand.Connection.Open(); B.SelectCommand.ExecuteNonQuery(); B.SelectCommand.Connection.Close(); DataTable C = new DataTable(); B.Fill(C); dataGridView1.DataSource = C; |
Это сообщение отредактировал(а) Partizan — 4.12.2008, 12:28
Профиль
Группа: Участник
Сообщений: 310
Регистрация: 15.11.2007
Репутация: нет
Всего: нет
Да уж(
и так не работате((((
Код |
OleDbDataAdapter B = new OleDbDataAdapter(«SELECT * FROM Содержание_заказа WHERE Дата=#»+dateTimePicker1.Value.ToString(«MM/dd/yyyy»)+»#», «Provider=Microsoft.Jet.OLEDB.4.0;» + «Data Source=» + @»….kafe.mdb»); |
Код |
Дата содержит синтаксическую ошибку в выражении запроса ‘Дата=#11.20.2008#’. |
Код |
SELECT * FROM Содержание_заказа WHERE Дата=#11.20.2008# |
Добавлено через 5 минут
Причем по моему не так:
ToString(«MM/dd/yyyy»)
а вот так:
ToString(«dd/MM/yyyy»)
ну всеравно не пашет((((
Это сообщение отредактировал(а) kuller — 4.12.2008, 12:32
Let’s do some .NET
Профиль
Группа: Модератор
Сообщений: 2828
Регистрация: 19.12.2005
Где: Санкт-Петербург
Загрузка…
Пытаюсь добавить в базу данных нового пользователя следующим способом:
DataModule2.ADOQuery1.SQL.Add('INSERT INTO Users (login,password) VALUES ('''+Edit1.Text+''', '''+Edit2.Text+''')');
DataModule2.ADOQuery1.ExecSQL;
ShowMessage('Успешно');
Но выдает ошибку «…Ошибка синтаксиса (пропущен оператор) в выражении запроса»
Что не так?
В таблице самой 3 поля: код, Login, password
-
Вопрос заданболее трёх лет назад
-
216 просмотров
Пригласить эксперта
Доброго. Ну, тут думать даже нечего. На самом деле ошибка синтаксиса, скорее всего с ‘
Возьми вот это всё ‘INSERT INTO Users (login,password) VALUES (»’+Edit1.Text+»’, »’+Edit2.Text+»’)’);
DataModule2.ADOQuery1.ExecSQL;
Загони в текстовую переменную вместе с данными, сам увидишь. Если не увидишь — выведи ее в Management Studio
Может числить сначала:DataModule2.ADOQuery1.SQL.Clear;
сейчас ошибка «ошибка синтаксиса инструкции insert into»
Проверьте текст запроса (SQL.Text) либо отладчиком, либо ShowMessage.
-
Показать ещё
Загружается…
09 июн. 2023, в 01:21
10000 руб./за проект
09 июн. 2023, в 01:06
50000 руб./за проект
09 июн. 2023, в 00:36
1000 руб./за проект
Минуточку внимания
imfrozen 0 / 0 / 1 Регистрация: 14.05.2012 Сообщений: 55 |
||||
1 |
||||
11.06.2016, 18:34. Показов 6159. Ответов 2 Метки нет (Все метки)
Добрый день.Пытаюсь сделать запрос на соединение таблиц,но получаю ошибку: Ошибка синтаксиса (пропущен оператор) в выражении запроса ‘nazv_otpFROM privoz_gruz INNER JOIN korabli ON privoz_gruz.id_ship = korabli.id_shipINNER JOIN port_otp ON privoz_gruz.port_otp = port_otp.id_port_otpr’.
Думаю что проблема в расставлении скобок.Подскажите пожалуйста
__________________ 0 |
ltv_1953 16778 / 6959 / 1548 Регистрация: 21.06.2012 Сообщений: 12,975 |
||||
12.06.2016, 08:07 |
2 |
|||
РешениеЕсли это Аксесс (согласно теме, а не разделу). то FROM примерно так (в приведенном запросе и скобок не хватает, и в конце какая-то каша …)
1 |
0 / 0 / 1 Регистрация: 14.05.2012 Сообщений: 55 |
|
12.06.2016, 09:17 [ТС] |
3 |
действительно, промахнулся с разделом, извиняюсь 0 |
|
|
|
INNER JOIN объединение 3 таблиц
, MS Access/ADO
- Подписаться на тему
- Сообщить другу
- Скачать/распечатать тему
|
|
Junior Рейтинг (т): 1 |
Написал запрос, объединяющий 3 таблицы INNER JOIN’ом ADOQuery1.SQL.Clear; ADOQuery1.SQL.Add(‘select BL.mkb,MKB.DESCR,SUM(BL.dni) as dni,D.fio,count(*) as kolvo’); ADOQuery1.SQL.Add(‘from BolList as BL ‘); ADOQuery1.SQL.Add(‘INNER JOIN Doctor as D ON BL.doctor=D.key ‘); ADOQuery1.SQL.Add(‘INNER JOIN MKB ON BL.mkb=mkb.code ‘); ADOQuery1.SQL.Add(‘where PolStac=»‘+PolStac+’»‘); ADOQuery1.SQL.Add(‘and Date>=:d1 and Date<=:d2’); ADOQuery1.Parameters.ParamByName (‘d1’).Value:=DateEdit1.Date; ADOQuery1.Parameters.ParamByName (‘d2’).Value:=DateEdit2.Date; ADOQuery1.SQL.Add(‘GROUP BY BL.mkb,D.fio,MKB.DESCR’); ADOQuery1.Active:=true;
выдает ошибку: Ошибка синтаксиса(пропущен оператор) в выражении запроса BL.doctor=D.key INNER JOIN MKB ON BL.mkb=mkb.code Может Access не дает объединять больше 2х таблиц? Добавлено 31.10.12, 12:13 ADOQuery1.SQL.Clear; ADOQuery1.SQL.Add(‘select BL.mkb,MKB.DESCR,SUM(BL.dni) as dni,D.fio,count(*) as kolvo’); ADOQuery1.SQL.Add(‘from BolList as BL,Doctor as D,MKB’); ADOQuery1.SQL.Add(‘where BL.doctor=D.key and BL.mkb=mkb.code and BL.mkb=mkb.code’); ADOQuery1.SQL.Add(‘and PolStac=»‘+PolStac+’»‘); ADOQuery1.SQL.Add(‘and Date>=:d1 and Date<=:d2’); ADOQuery1.Parameters.ParamByName (‘d1’).Value:=DateEdit1.Date; ADOQuery1.Parameters.ParamByName (‘d2’).Value:=DateEdit2.Date; ADOQuery1.SQL.Add(‘GROUP BY BL.mkb,D.fio,MKB.DESCR’); ADOQuery1.Active:=true; Но вопрос про INNER JOIN не снимается, почему в данном случае не работает он? |
Gonarh |
|
ADOQuery1.SQL.BeginUpdate; ADOQuery1.SQL.Clear; ADOQuery1.SQL.Add(‘select BL.mkb,MKB.DESCR,SUM(BL.dni) as dni,D.fio,count(*) as kolvo’); … ADOQuery1.SQL.Add(‘GROUP BY BL.mkb,D.fio,MKB.DESCR’); ADOQuery1.SQL.EndUpdate; … |
sansans |
|
Почему бы не использовать неплохой конструктор запросов самого Аксесса, чтобы посмотреть как на самом деле текст запроса должен выглядеть. |
int 21h |
|
Junior Рейтинг (т): 1 |
2 sansans, спасибо помогло. Оказывается в синтаксисе Access INNER JOIN берется в скобки SELECT * FROM (BolList INNER JOIN doctor ON BolList.Doctor = doctor.key) INNER JOIN mkb ON BolList.mkb = mkb.CODE; |
Fr0sT |
|
Хоть трабл был и не в этом, но кто ж добавляет кусок запроса после присваивания параметров |
0 пользователей читают эту тему (0 гостей и 0 скрытых пользователей)
0 пользователей:
- Предыдущая тема
- Delphi: Базы данных
- Следующая тема
[ Script execution time: 0,1050 ] [ 16 queries used ] [ Generated: 30.01.23, 16:30 GMT ]
dsultan
14.04.08 — 16:48
подключаюсь к dbf через microsoft.jet
запутался в joinах, вот что выдает
Ошибка синтаксиса (пропущен оператор) в выражении запроса ‘ttl.ACCID = accs.ID INNER JOIN 1SACCS AS accs2 ON accs.SCHKOD >= accs2.SCHKOD’.
если убрать второй джойн — не ругается
где собака?
SELECT ttl.ACCID AS schet, ttl.CURRID AS valut,
iif(ttl.VSC0 = ‘ EL’,ttl.SC0,iif(ttl.VSC1 = ‘ EL’,ttl.SC1,
iif(ttl.VSC2 = ‘ EL’,ttl.SC2,0))) AS sk1, iif(KIND = ‘1’,ttl.SD
,0) AS sumost, iif(KIND = ‘2’,ttl.SD,0) AS valsumost,
iif(KIND = ‘3’,ttl.SD,0) AS kolost
FROM 1SBKTTL AS ttl
INNER JOIN
1SACCS AS accs ON ttl.ACCID = accs.ID
INNER JOIN
1SACCS AS accs2 ON accs.SCHKOD >= accs2.SCHKOD AND LEFT(accs.SCHKOD,LEN(accs2.SCHKOD)) = accs2.SCHKOD
AND accs.PLANID = 809 AND accs2.ID = ‘ 1V ‘
WHERE (ttl.date = #1/1/2008#) AND (ttl.KIND IN (‘1’, ‘2’, ‘3’)) AND (‘ EL’ IN (ttl.VSC0,
ttl.VSC1, ttl.VSC2))
sapphire
1 — 14.04.08 — 16:54
Попробуй, если ты используешь INNER JOIN
использовать select … from {перечень таблиц} where {условие выборки} AND {условия соединений}
sapphire
2 — 14.04.08 — 16:56
SELECT ttl.ACCID AS schet, ttl.CURRID AS valut,
iif(ttl.VSC0 = ‘ EL’,ttl.SC0,iif(ttl.VSC1 = ‘ EL’,ttl.SC1,
iif(ttl.VSC2 = ‘ EL’,ttl.SC2,0))) AS sk1, iif(KIND = ‘1’,ttl.SD
,0) AS sumost, iif(KIND = ‘2’,ttl.SD,0) AS valsumost,
iif(KIND = ‘3’,ttl.SD,0) AS kolost
FROM 1SBKTTL AS ttl, 1SACCS AS accs, 1SACCS AS accs2
WHERE
((ttl.date = #1/1/2008#) AND (ttl.KIND IN (‘1’, ‘2’, ‘3’)) AND (‘ EL’ IN (ttl.VSC0,
ttl.VSC1, ttl.VSC2)))
AND
(
accs ON ttl.ACCID = accs.ID AND accs.SCHKOD >= accs2.SCHKOD AND LEFT(accs.SCHKOD,LEN(accs2.SCHKOD)) = accs2.SCHKOD
AND accs.PLANID = 809 AND accs2.ID = ‘ 1V ‘
)
dsultan
3 — 14.04.08 — 17:21
(2) пустоту вернул
sapphire
4 — 14.04.08 — 17:31
(3) Если положение dbf-ок статично, можно создать mdbшник и прилепить к нему через связь с таблицами запрос внутри. Так делают, когда хотят уйти от ограничений ядра jet
dsultan
5 — 14.04.08 — 17:35
все ок, спасибо, при копипасте пробелы в ‘ 1v ‘ потерялись, и еще заодно узнал, что planID в dbf лежит 36ричный, а в sql версии десятичный
sapphire
6 — 14.04.08 — 17:36
(5)
dsultan
7 — 14.04.08 — 17:37
(4) я так и делаю для дебага, удобно в акцесе проверять
одно смущает — тот же самый запрос через тот же джет акцес выдает результат мгновенно, а прога отбирает что то долго
sapphire
8 — 14.04.08 — 17:37
+(4) Иногда лучше использовать драйвер FoxPro (см документацию к 1С++),
или через Access. Кстати, частенько Accessовские БД используют для диагностики.
sapphire
9 — 14.04.08 — 17:38
(7) Правильно, потому что ты не используешь индексы.
dsultan
10 — 14.04.08 — 17:39
(8) я и начал с фокспрошного драйвера, уперся в форматы дат, устал бодаться, решил джет попробовать
dsultan
11 — 14.04.08 — 17:41
а их можно через джет использовать?
КонецЦикла
12 — 14.04.08 — 17:47
(10) Юзай ОлеДБ, 1С++ и поиск
Хватит долбить
КонецЦикла
13 — 14.04.08 — 17:48
Кроме того уже есть аккаунтрекордсет
dsultan
14 — 14.04.08 — 18:07
(12)а чем джет не оледб?
делал уже через 1с++, быстрые итоги, все супер, только оказалось, что с dbf они не работают
самому переписывать быстрые итоги под dbf что то влом
спрофайлил то, что они запрашивают, пытаюсь приладить
(13) это к чему?
Форум программистов Vingrad
[ Script execution time: 0,1050 ] [ 16 queries used ] [ Generated: 30.01.23, 16:30 GMT ]
dsultan 14.04.08 — 16:48 подключаюсь к dbf через microsoft.jet запутался в joinах, вот что выдает Ошибка синтаксиса (пропущен оператор) в выражении запроса ‘ttl.ACCID = accs.ID INNER JOIN 1SACCS AS accs2 ON accs.SCHKOD >= accs2.SCHKOD’. если убрать второй джойн — не ругается где собака? SELECT ttl.ACCID AS schet, ttl.CURRID AS valut, iif(ttl.VSC0 = ‘ EL’,ttl.SC0,iif(ttl.VSC1 = ‘ EL’,ttl.SC1, iif(ttl.VSC2 = ‘ EL’,ttl.SC2,0))) AS sk1, iif(KIND = ‘1’,ttl.SD ,0) AS sumost, iif(KIND = ‘2’,ttl.SD,0) AS valsumost, iif(KIND = ‘3’,ttl.SD,0) AS kolost FROM 1SBKTTL AS ttl INNER JOIN 1SACCS AS accs ON ttl.ACCID = accs.ID INNER JOIN 1SACCS AS accs2 ON accs.SCHKOD >= accs2.SCHKOD AND LEFT(accs.SCHKOD,LEN(accs2.SCHKOD)) = accs2.SCHKOD AND accs.PLANID = 809 AND accs2.ID = ‘ 1V ‘ WHERE (ttl.date = #1/1/2008#) AND (ttl.KIND IN (‘1’, ‘2’, ‘3’)) AND (‘ EL’ IN (ttl.VSC0, ttl.VSC1, ttl.VSC2))
sapphire 1 — 14.04.08 — 16:54 Попробуй, если ты используешь INNER JOIN
sapphire 2 — 14.04.08 — 16:56 SELECT ttl.ACCID AS schet, ttl.CURRID AS valut, iif(ttl.VSC0 = ‘ EL’,ttl.SC0,iif(ttl.VSC1 = ‘ EL’,ttl.SC1,
dsultan 3 — 14.04.08 — 17:21 (2) пустоту вернул
sapphire 4 — 14.04.08 — 17:31 (3) Если положение dbf-ок статично, можно создать mdbшник и прилепить к нему через связь с таблицами запрос внутри. Так делают, когда хотят уйти от ограничений ядра jet
dsultan 5 — 14.04.08 — 17:35 все ок, спасибо, при копипасте пробелы в ‘ 1v ‘ потерялись, и еще заодно узнал, что planID в dbf лежит 36ричный, а в sql версии десятичный
sapphire 6 — 14.04.08 — 17:36 (5)
dsultan 7 — 14.04.08 — 17:37 (4) я так и делаю для дебага, удобно в акцесе проверять
sapphire 8 — 14.04.08 — 17:37 +(4) Иногда лучше использовать драйвер FoxPro (см документацию к 1С++),
sapphire 9 — 14.04.08 — 17:38 (7) Правильно, потому что ты не используешь индексы.
dsultan 10 — 14.04.08 — 17:39 (8) я и начал с фокспрошного драйвера, уперся в форматы дат, устал бодаться, решил джет попробовать
dsultan 11 — 14.04.08 — 17:41 а их можно через джет использовать?
КонецЦикла 12 — 14.04.08 — 17:47 (10) Юзай ОлеДБ, 1С++ и поиск
КонецЦикла 13 — 14.04.08 — 17:48 Кроме того уже есть аккаунтрекордсет dsultan 14 — 14.04.08 — 18:07 (12)а чем джет не оледб? самому переписывать быстрые итоги под dbf что то влом (13) это к чему?
Вопрос: Я выполняю задание на класс, и я нахожусь на своем конце. В принципе, мне нужно написать запрос, который использует Шаг 1. Создайте представление обо всех столбцах (только один раз столбцы столбцов, если столбцы дублируются в таблицах) во всех таблицах базы данных лекций 5. Сохраните этот запрос как Lecture_5_View и нам этот запрос, чтобы построить следующие 3 запроса. В предложении “FROM” вы должны использовать “INNER JOIN” в этом запросе. Помните, что ACCESS не поддерживает команду “CREATE VIEW”, поэтому вы должны создать запрос выбора. ‘ Вот скриншот базы данных, в которой показаны все заголовки и заголовки столбцов. Основываясь на других сообщениях, подобных этому, я подумал, что это будет довольно просто. У меня это до сих пор, но он не хочет запускать
Где я буду ошибаться до сих пор и как выполнить этот запрос? Большое спасибо, Джош Лучший ответ: При использовании Access вам необходимо использовать круглые скобки при выполнении нескольких соединений:
Это очень важно, если вы разделите свой запрос так, чтобы у вас было не более одного соединения в каждом разделе, т.е. Ваш первый запрос:
Тогда у вас есть:
Это немного отличается от подзапросов, поскольку вы все еще можете ссылаться на все поля из Таблицы 1 и Таблицы2. РЕДАКТИРОВАТЬ Чтобы избежать дублирования столбцов, вам нужно явно указать нужные столбцы (хотя вы все равно должны это делать):
Ответ №1 Попробуй это:
Возможно, вам также будет интересно:
Подписаться
авторизуйтесь
0 комментариев
Старые
|