Monday 11 February 2008

За колегите: Упражнявайте базите данни!

Здравейте, на нашата "голяма" Група!

В чекмеджето на нашата обща пощенска кутия (softuerni_07@вие.знаете.къде) днес сложих едно архивче. Целта му е да улесни всички при упражненията по бази данни.
Работата е там, че ни преподават основите на езика SQL чрез MS-SQL сървър. Само инсталацията на това чудовище е около едно CD, да не говорим колко пространство ще заеме на твърдия диск. Е, нужно ли е да използваш балистична ракета за да убиеш комар? (Аналогията не е много добра, защото всъщност езика SQL е по-голямото и значимо нещо отколкото иснтрумента, в който се използва. Но това е друга тема.) Тогава как да си помогнем за упражненията? Как да започнем с изучаването на един от най-лесните, приятни и мощни езици? Тук ще дам три връзки, които предоставят само едно първоначално насочване:
  1. SQLite - проектът. Сайтът на една наистина оригинална и все по-популярна идея.
  2. SQLite в Wikipedia - нещата обяснени малко по-подробно.
  3. SQL в W3Schools - едно много достъпно входно ниво за езика, с реална възможност за изпробване на наученото онлайн.

Що се отнася до файловете в архива:
  1. sqlite3.exe - тази самостоятелна програмка е напълно достатъчна за да си направите и редактирате база данни от командната линия (DOS Prompt). Ако все пак не обичате черния екран с мигащата чертичка, можете да използвате другата програмка
  2. SQLiteSpy.exe - това е графичната обвивка на горната програма - един малък, но достатъчно добър редактор, в който бързо се създават обектите на базата данни и се пишат заявките. Да, така е - всичко става много по-лесно, когато е визуално ориентирано.
  3. SQLiteSpy.db3 и World.db3 - съотвтно пък са две примерни бази от данни. Да, тук базата данни е един единствен файл в *.db3 формат (от 3-та версия на SQLite).

По-простичко трудно би могло да бъде, особено като се има предвид, че SQLite покрива минимум CRUD принципа (какво представлява той можете да разберете отново от Wikipedia) заложен в SQL стандарта. Накратко казано този принцип е свързан с базовите операции, които използваме при работата си с обектите на базата данни:
  • Create - това са операциите свързани със създаване на обекти и записи от данни (CREATE, INSERT).
  • Read или Retrieve се отнася до операциите за извличане на данни (SELECT, JOIN, UNION).
  • Update е свързан с операциите за обновяване на съществуващите данни в базата (ALTER, UPDATE).
  • Delete има отношение към изтриването на обекти и данни (DROP, DELETE).
Тук не е включена само функционалността за възстановяване и конкурентен достъп до данните (чрез COMMIT / ROLLBACK блокове), но това са по-скоро допълнителни екстри на сървърите и се отнасят за групово изпълнение на останалите опреции по извличане и модификации на данни и обекти.
Надявам се, че SQLite ще ви е от полза при изучаването на базите от данни.

Friday 1 February 2008

Lets speak some more Linux: Ubuntu-server

This post should be called: Ubuntu 7.10 Server edition or the struggle of a newbie with the console.

So the main question is - how to make things happen?

If you have less than moderate experience with the terminal it might be quite a test. And I would almost make a mistake - at first I panicked and took a wrong path but first things first...


Installing the server edition of the fine Ubuntu system is not much different from the variant with the alternate cd. You have this text mode installer, which asks you almost the same things. Almost. Lets point some situations:

* In the first place I shouldn't let it configure the network through the DHCP. Not a problem - fixable situation but cost me time to figure it out for I'm almost completely unfamiliar with the networking and stuff (ashamed).

* In the second place - the big advantage of the server edition is that it asks you to choose from and installs for you
  • DNS server - lets you provide and use the DNS (Domain Name System) service.
  • LAMP server - tool-chain for web developers, including Apache Web server, MySQL database server and PHP/Perl/Python programming languages, all these tuned for Linux.
  • Mail Server - managing electronic mail is always useful.
  • OpenSSH server - the free distribution of the server, which manages secure shell connections.
  • PostgreSQL Server - powerful and robust object-relational database server.
  • Print Server - manages the printers in the office and the jobs assigned to them.
  • Samba file server - this one lets you have a seamless local network and file-sharing system along with Windows machines.
with just one after you've made your mind.
CAUTION! - at this version (7.10 - the Gutsy Gibbon) just skip the mail server. Installing it cost me reinstalling the system - after rebooting the new system, you end up sudo-less, which in Ubuntu means you have no eyes, you have no ears and you definitely have no fingers. This is a situation where you basically have only around two toes on the left foot. That's all. And if you can manage the whole system this way you must be quite a guru.

* I wont address here the issue of partitioning the hard drives (especially when speaking for software RAID), because it is an enormous and quite different subject (in my case the partitioning was already done and I just formatted the available partitions).

* If you're connected to Internet the ATP will want to configure itself. This process may substantially slow down at 40%, 60% or 80% or just take forever. I had once the last case - on the next morning I should start the installation again. Somewhere in the Ubuntu forums someone said it happens sometimes. An easy work-around is if you just unplug the PC from the network, so you'll just let the APT will configure itself later.

After installing the specialized servers (remember! NO Mail Server in Gutsy!) it is almost done. If there are no glitches and delays the whole installation may take around twenty minutes. Cool! :)

There. After the reboot you're already there - at your shiny terminal. Don't forget that in Ubuntu you have up to seven virtual terminals (accessible by pressing Ctrl-Alt + F1 to F7).
So what's first?
For a moment I didn't know what to do. But there are things that must be done: check your network for example

Getting to know the console of your distro is like slowly and inevitably falling in love. Its like raising a child (not that I have one but you know what I mean).

....
And the lost path of thoughts made this post unproperly finished. But as long as this whole blog is some sort of a draft I publish it in such state. If questioned, answeres will be sought and eventually provided.

Честит Рожден Ден!

Днес моят много-уважаван колега, Тошко достигна Христовата възраст! Айде, живот и здраве и като утроиш тези две тройки да се радваш на много правнуци ;)

И купонът си е купон, но работата си е работа и за това трябва да се захващам със следващия пост...

Много здраве и голяма веселба!