S. D. F. - [7]
( cnum integer,
cname char (10),
city char (10),
rating integer,
snum integer );
CREATE TABLE Orders
( onum integer,
amt decimal,
odate date,
cnum integer,
snum integer );
«конец кода»
- 3. Тут есть нюанс, который я еще не понял, но после создания таблицы, она не активна!?! Потом попробуешь, и возможно найдешь красивое решение. А пока закрой программу, затем запусти ее вновь и открой свою базу. Этого достаточно.
- 4. Сделай следующий файл и выполни:
«начало кода»
INSERT INTO Salespeople (snum,sname,city ,comm)
VALUES (1001,'Peel','London',.12);
INSERT INTO Salespeople (snum,sname,city ,comm)
VALUES (1002,'Serres','San Jose',.13);
INSERT INTO Salespeople (snum,sname,city ,comm)
VALUES (1004,'Motika','London',.11);
INSERT INTO Salespeople (snum,sname,city ,comm)
VALUES (1007,'Rifkin','Barcelona',.15);
INSERT INTO Salespeople (snum,sname,city ,comm)
VALUES (1003,'Axelrod','New York',.10);
INSERT INTO Customers (cnum,cname,city,rating,snum)
VALUES (2001,'Hoffman','London',100,1001);
INSERT INTO Customers (cnum,cname,city,rating,snum)
VALUES (2002,'Giovanni','Rome',200,1003);
INSERT INTO Customers (cnum,cname,city,rating,snum)
VALUES (2003,'Liu','San Jose',200,1002);
INSERT INTO Customers (cnum,cname,city,rating,snum)
VALUES (2004,'Grass','Berlin',300,1002);
INSERT INTO Customers (cnum,cname,city,rating,snum)
VALUES (2006,'Clemens','London',100,1001);
INSERT INTO Customers (cnum,cname,city,rating,snum)
VALUES (2008,'Cisneros','San Jose',300,1007);
INSERT INTO Customers (cnum,cname,city,rating,snum)
VALUES (2007,'Pereira','Rome',100,1004);
INSERT INTO Orders (onum,amt,odate,cnum,snum)
VALUES (3001,18.69,'10/03/1990',2008,1007);
INSERT INTO Orders (onum,amt,odate,cnum,snum)
VALUES (3003,767.19,'10/03/1990',2001,1001);
INSERT INTO Orders (onum,amt,odate,cnum,snum)
VALUES (3002,1900.10,'10/03/1990',2007,1004);
INSERT INTO Orders (onum,amt,odate,cnum,snum)
VALUES (3005,5160.45,'10/03/1990',2003,1002);
INSERT INTO Orders (onum,amt,odate,cnum,snum)
VALUES (3006,1098.16,'10/03/1990',2008,1007);
INSERT INTO Orders (onum,amt,odate,cnum,snum)
VALUES (3009,1713.23,'10/04/1990',2002,1003);
INSERT INTO Orders (onum,amt,odate,cnum,snum)
VALUES (3007,75.75,'10/04/1990',2004,1002);
INSERT INTO Orders (onum,amt,odate,cnum,snum)
VALUES (3008,4723.00,'10/05/1990',2006,1001);
INSERT INTO Orders (onum,amt,odate,cnum,snum)
VALUES (3010,1309.95,'10/06/1990',2004,1002);
INSERT INTO Orders (onum,amt,odate,cnum,snum)
VALUES (3011,9891.88,'10/06/1990',2006,1001);
«конец кода»
- Все должно пройти хорошо.
* Брюки превращаются, превращаются брюки… в элегантную базу данных. Все ОК.
- Теперь заготовка базы у нас есть, и мы можем выполнять запросы из книги [1] выполнятся будут 3 задачи:
- 1. Самообучение SQL.
- 2. Вычитывание книги (с исправлением опечаток)
- 3. Тестирование программы.
* Значит теперь, со всеми переделками, программа сможет выполнить любой запрос?
- Это предстоит проверить.
Прошло три дня.
- Нет, ребята, пулемета я вам не дам.
- В книге оказалось, очень много ошибок. Ну, очень много ошибок, и все они полезные.
* Догадываюсь, задумано издевательство.
- Точно! Мне так понравилась идея с ошибками, что я задумался, не наделать их и в этом тексте.
* Вот этого, не надо!
- Хорошо, но ошибки неизбежны, где-то что-то я упущу, в этом случае я сделаю вид, что все так и задумано…
* Ну, ты и жук!
- Учись, студент. Учись, как сдавать программу заказчику, главное держать невозмутимое выражение морды лица: “Как, при запуске программы включилось форматирование диска? Ну, это у вас устаревший Windows, давайте я его переставлю, это будет стоить… что, при этом утеряны данные за 3 года работы. Но, это же хорошо (хорошо-то хорошо, да ничего хорошего – что бы еще соврать) – Слава, Богу, это был только сон…”
* Хе-хе, ну у тебя и шуточки. Давай все-таки вернемся к книге [1].
- Да! Как я уже раньше думал сказать, если бы все примеры в книге были бы без ошибок, пользы от нее было бы намного меньше. Копируй запросы, выполняй, проверяй результат… скучно. А тут, наполненная описками жизнь бурлит и хлещет.
* И какие там ошибки?
- Например:
SELECT sname, sity
FROM Salespeople;
WHERE city=LONDON;
или еще:
SELECT * FROM Order WHERE NOT
((odate=10/03/1990 AND cnum < > 1002)OR amt > 2000.00);
- Тут пару ошибок достаточно очевидны (лишний символ “;” и нет апострофов вокруг даты ну и прочее, и прочее.
- В процессе поиска ошибок, возникла потребность изменить программу. А именно, при ошибке выводится сообщение, и часто там указывается на какой строке, и в какой позиции найдена ошибка. Проблема в том, что на исполнение мы даем запрос одной строкой, и соотнести место ошибки, с тем, что на экране…
- Посему, изменяем RunSQL
В разделе переменных добавляем:
LPos : integer; // позиция ошибки
- Между строками 330 и 340 добавляем текст:
330 begin // была ошибка
331 Memo1.Clear;
332 Memo1.Lines.Add(S); // перезапись запроса одной строкой
333 LPos := GetSelStart(Mistake); // поиск места ошибки
334 if LPos > -1 then begin
335 Memo1.SelStart := LPos-1; // вкл индикатора
336 Memo1.SelLength := 1;
337 Memo1.SetFocus;
338 Panel5.Caption := IntToStr(LPos); // дополнительная информ.
![Задачник по программированию для школы](/storage/book-covers/61/616ec53a107ad4719031fe73920c6823143d0f2f.jpg)
Задачи для школьника, должны быть веселы!На наших занятиях, запрещена фраза "мы это не проходили" - если это надо для решения задачи - "пройди", источников море, учитель подскажет.Не получается? Возможно, ты выбрал задачу не по силам, ничего - это тоже опыт, отложи, попробуй следующую. Мало решить задачу, придумай свою...Ученик должен уметь: (поставить задачу + решить задачу + учиться) * n ...
![Система Диофанта](/build/oblozhka.dc6e36b8.jpg)
Если вы хотите поразить одноклассников молниеносным решением квадратных уравнений [КУ], давайте развлечемся.
![Записки очевидца необъявленной войны. Том 2](/storage/book-covers/2f/2f40b6e7c81628a2f4a0c5e7dd1964be69c5b417.jpg)
«Записки очевидца необъявленной войны» — это взгляд на войну в Донбассе глазами местного жителя. В данном томе речь пойдет о событиях второго периода войны, начавшегося в сентябре 2014 г. с подписания «Минска-1». Помимо этого, в книге также рассматриваются преступления обеих воюющих сторон, роль пропаганды в СМИ и методы противостояния ей, значительное внимание уделено положению мирного населения Донбасса.
![Записки очевидца необъявленной войны. Том 1](/storage/book-covers/12/12c472ffdbef52b6662f49deea27719e429ba022.jpg)
«Записки очевидца необъявленной войны» — это взгляд на войну в Донбассе глазами местного жителя. В первом томе речь идет о событиях с ноября 2013 по сентябрь 2014 г. Среди них — киевский майдан, антимайдановские протесты, события в Крыму, трагедия 2 мая в Одессе, оборона Славянска, падение малазийского Боинга, бои за Шахтерск, Саур-Могилу, Иловайск и многие другие события.
![Учебник Любви](/storage/book-covers/e0/e0916282b3b52be142c87e6a0f49ca3047ecf304.jpg)
Несмотря на громкое название, книга не претендует на роль настольной книги в любовных отношениях. В ней собраны наблюдения, фантазии и личный опыт автора. Все грани этого прекрасного чувства не дано испытать никому, но и запретного в этой теме быть не может, иначе Любовь была бы неполной. У каждого человека отношение к любви индивидуально, но, полагаю, никто не будет спорить с тем, что она существует. А если так, то, как и по любой другой теме, по ней должно быть хоть какое-то пособие.
![Любовь, смерть и другие неприятности. 2006–2016 в стихах](/storage/book-covers/fa/fac021ccd13263f7cc7c254c6b52313e3b193836.jpg)
Стихи за чуть больше десяти лет — от восемнадцати до двадцати девяти — любовь, смысл жизни, друзья и путешествия, поиски стиля и неудобные вопросы.
![Кто вы здесь, в Америке?](/storage/book-covers/77/77ca08545546e8d9bb98f149dff0aaad43a94704.jpg)
В книге рассказывается история главного героя, который сталкивается с различными проблемами и препятствиями на протяжении всего своего путешествия. По пути он встречает множество второстепенных персонажей, которые играют важные роли в истории. Благодаря опыту главного героя книга исследует такие темы, как любовь, потеря, надежда и стойкость. По мере того, как главный герой преодолевает свои трудности, он усваивает ценные уроки жизни и растет как личность.