Waiting for 9.1 – adding values to enums

Finally, on 25th of October, Tom Lane committed patch which does:

Allow new values to be added to an existing enum type.
 
After much expenditure of effort, we've got this to the point where the
performance penalty is pretty minimal in typical cases.
 
Andrew Dunstan, reviewed by Brendan Jurd, Dean Rasheed, and Tom Lane

Continue reading Waiting for 9.1 – adding values to enums

Waiting for 9.1 – Suffix matching in pg_hba.conf

On 24th of October, Peter Eisentraut committed addition to his previous patch, which adds:

Support suffix matching of host names in pg_hba.conf
 
A name starting with a dot can be used to match a suffix of the actual
host name (e.g., .example.com matches foo.example.com).

Continue reading Waiting for 9.1 – Suffix matching in pg_hba.conf

Grouping data into time ranges

Today some guy on IRC asked question, which I didn't fully understand, but which could (probably) be summarized: how to group data into 5 minute intervals, based on some timestamp column.

Well, it seems trivial (as long as you know how to do it), but since he clearly didn't know how to do it (or I misunderstood his problem), here's the explanation:

Continue reading Grouping data into time ranges

Reduce bloat of table without long/exclusive locks

Some time ago Joshua Tolley described how to reduce bloat from tables without locking (well, some locks are there, but very short, and not really intrusive).

Side note: Joshua: big thanks, great idea.

Based on his idea and some our research, i wrote a tool which does just this – reduces bloat in table.

Continue reading Reduce bloat of table without long/exclusive locks

Waiting for 9.1 – triggers on views

On 10th of October, Tom Lane committed patch by Deal Rasheed, which adds triggers on views:

Support triggers ON views.
 
This patch adds the SQL-standard concept OF an INSTEAD OF TRIGGER, which
IS fired instead OF performing a physical INSERT/UPDATE/DELETE.  The
TRIGGER FUNCTION IS passed the entire OLD AND/OR NEW ROWS OF the VIEW,
AND must figure OUT what TO do TO the underlying TABLES TO implement
the UPDATE.  So this feature can be used TO implement updatable views
USING TRIGGER programming STYLE rather than rule hacking.
 
IN passing, this patch corrects the names OF SOME COLUMNS IN the
information_schema.triggers VIEW.  It seems the SQL committee renamed
them somewhere BETWEEN SQL:99 AND SQL:2003.
 
Dean Rasheed, reviewed BY Bernd Helmle; SOME additional hacking BY me.

Continue reading Waiting for 9.1 – triggers on views

Obsługa klienta (polish only)

Ostatnio dostałem linka do prostej “info-grafiki" pokazującej jakie są przyczyny utraty klientów.

Najważniejszą jest: obsługa klienta. W/g wspomnianej grafiki, obsługa klienta odpowiada za 68% przypadków gdy tracisz klienta. WOW. To sporo. Zacząłem się nad tym trochę zastanawiać.

W różnych badaniach wychodzi, że jednym z kryteriów wyboru jest cena. Ważnym. Więc może cena odpowiada za utratę klienta? Niespecjalnie. Klienci zwabieni najniższą ceną zostawią cię natychmiast gdy ktoś zaoferuje im cenę o 1 grosz niższą, więc jako tacy non stop migrują. A klient którego tracisz to taki klient którego wcześniej miałeś.

Pomyślałem o tym trochę i przyznałem temu 100% racji. W różnych sytuacjach korzystam z rożnych firm/usług, i zazwyczaj jeśli coś mnie odrzuca to właśnie obsługa klienta (lub jej brak). Jeśli jestem zadowolony z obsługi to jestem gotów na pewne niewygody czy wyższe koszty – tylko i wyłącznie dzięki temu, że “po drugiej stronie" ktoś się uśmiechnął czy powiedział coś fajnego. Czy wyszedł na moment ze swojej roli i pomyślał jak mi faktycznie pomóc.

Trzy przykłady z mojego podwórka, dwa negatywne i jeden pozytywny.

Jak większość znających mnie wie, lubię samochody Mitsubishi. Miałem już 3 (z czego 2 nadal mam), poniekąd “przeze" mnie, znajomy kupił, i ogólnie co jakiś czas im jakiś “PR" robię.

Ostatnio znajoma (no, rodzinno-znajoma) firma, szukała samochodów. Nigdy “miśków" nie używali, ale stwierdzili, że zobaczą. Pojechali do Mitcaru. Pogadali na miejscu. Poprosili o wysłanie oferty na 3 samochody (łącznie około 200k pln). To było jakoś tak w ostatnim tygodniu września.

W poniedziałek pogadałem z nimi, i stwierdzili, że miśka nie kupią, bo nikt im nie odpowiedział. No cóż. Ja wiem, że Mitcar jest niekontaktowy (nie odpisali na zapytanie o Colta, którego kupiłem potem gdzie indziej, ani o Grandisa, ani o przemalowanie samochodu. Tak jakby nie czytali maili.), więc w ich imieniu skontaktowałem się z AutoGT. I tu zobaczyłem obsługę. W ciągu godziny miałem informację co, jak, co muszę powiedzieć, z czego i co mogę wybrać. Do końca dnia (mail przyszedł o 18:02!) dostałem ofertę wariantową, z warunkami cenowymi. Następnego dnia – opcje leasingu.

I życie stało się prostsze. Mitcar nie chciał sprzedać ( chciałbym móc powiedzieć, że pewnie mają tyle klientów, że te dodatkowe 200k im “wisi", ale jakoś nie sądzę by to była prawda), więc sprzedaż zaliczy AutoGT.

Inny przykład na obsługę. Od bardzo dawana lubiłem, ceniłem i polecałem wszystkim dookoła “Supermarket EMMA" w Ursusie. Olbrzymi wybór, miła atmosfera. Robiłem tam non stop zakupy, mimo, że ceny były dużo wyższe (przykład: bułeczka typu mikro-paluch, długości 10-15cm, za 99 groszy, gdzie indziej podobna kosztowała powiedzmy połowę tego).

Potem kilka razy zdarzyło się im sprzedać nieświeżą (mocno nieświeżą) rybę i wędliny. I tak się skończyło. Przerzuciłem się na Piotra i Pawła i/lub Almę. Ale niesmak pozostał.

Zastanawiałem się: skąd się to bierze. Czemu firma “x" olewa klienta – np. nie odpowiadając na maile i nie wysyłając swoich, 2 miesiące po wzięci zaliczki za coś co miało być zrobione z 6 tygodni? I znalazłem odpowiedź. Prostą. To nasza wina. Nasza – konsumentów. Kupujących, korzystających z usług. Godzimy się na to “no bo w końcu to dostanę", albo “no to kupię inny samochód" czy “zadzwonię i się dopytam czemu nie ma".

Tak nie może być. Oczywiście liczenie na jakieś federacje klientów czy tego podobne bzdury nie zadziała. Ale – skoro mamy praktycznie wszyscy dostęp do sieci – to może zacznijmy pisać o takich sytuacjach na blogach/blipie, itd.

Bo nawet jeśli akurat Twojego “nikt" nie czyta, to zawsze czyta go Google. I następnym razem jak ktoś wpisze w google'a hasło będącą nazwą firmy, niech ma szanse się dowiedzieć, że firma: “nie odpowiada na maile, nie podaje działającego telefonu, nie wysyła zamówionych ofert, zatrudnia ludzi którzy starają się kantować klientów" i tym podobne.

Każdy głos z osobna nie znaczy wiele. Ale może za jakiś czas, łączna suma tych postów spowoduje zmiany. Może nasze dzieci nie będą musiały kombinować by dostać wycenę samochodu, czy pójdą do sklepu bez obaw o to, że sprzedawca wciśnie im nieświeżą rybę.

Ostatnie ale – pisząc – podawajcie nazwy firm. Spotkałem się z sytuacjami, że ktoś opisując tragiczną obsługę nie podawał nazwy firmy by “nie robić im reklamy". To bardzo złe. Bez nazwania ich po imieniu, o tym kogo problem dotyczy będzie wiedziało bardzo małe grono osób. A zależy nam o tym by dowiedziało się jak najwięcej – jeśli dane firma odczuje “w portfelu", że coś jest źle, to może zmieni odpowiednich ludzi i przestanie być złym przykładem.

Oczywiście pozytywne przykłady też powinny być opisywane – choćby po to by w Google'u mieć “przegląd sytuacji", a nie same negatywy.

Performance gains from using foreign keys

Foreign keys are known for couple of things, but speeding up your system is not one of them. But sometimes, having them in place lets you make queries significantly faster.

How? Let me show you example I have seen lately (well, it's simplified example based on something much more convoluted, and definitely longer):

Continue reading Performance gains from using foreign keys