DevProTalk

Forumi IT profesionalaca
web development, web design, e-business, SEO


Idite nazad   DevProTalk > Web development i web aplikacije > SQL baze podataka - Sponzor: Baze-Podataka.net
Želite da se reklamirate ekskluzivno na ovoj poziciji? Javite se

SQL baze podataka - Sponzor: Baze-Podataka.net MySQL, MSSQL, Oracle, Access, ODBC. Ako imate problem brže i preciznije ćete dobiti odgovor ako priložite strukturu tabela ili skript koji kreira tabele i puni ih test podacima umesto što to problem opisujete samo rečima. Sponzor: Baze-Podataka.net - Blog o bazama podataka

Odgovori
 
Alati teme Način prikaza
Staro 29. 01. 2006.   #1
bluesman
Goran Pilipović
Sir Write-a-Lot
 
Avatar bluesman
 
Datum učlanjenja: 18.05.2005
Lokacija: Beograd
Poruke: 5.450
Hvala: 288
1.247 "Hvala" u 446 poruka
bluesman je osoba koju treba slušatibluesman je osoba koju treba slušatibluesman je osoba koju treba slušatibluesman je osoba koju treba slušatibluesman je osoba koju treba slušatibluesman je osoba koju treba slušatibluesman je osoba koju treba slušatibluesman je osoba koju treba slušatibluesman je osoba koju treba slušati
Pošaljite ICQ poruku za bluesman
Default Promena prikaza TIMESTAMP polja u MySQL

Danas sam, na tezi nacin, naucio najnoviji "feature" MySQL.

Citat:
From MySQL 4.1.0 on, TIMESTAMP display format differs from that of earlier MySQL releases:
  • TIMESTAMP columns are displayed in the same format as DATETIME columns. In other words, the display width is fixed at 19 characters, and the format is YYYY-MM-DD HH:MM:SS.
  • Display widths (used as described in the preceding section) are no longer supported. In other words, for declarations such as TIMESTAMP(2), TIMESTAMP(4), and so on, the display width is ignored.
Izvod iz mysql manual

Dakle, svi koji koriste timestamp(14) i ocekuju vrednost polja: YYYYMMDDHHIISS mogu da se oproste od toga pošto se vraća klasičan DATETIME.

Ja iskreno ne znam razlog ovakvoj promeni.

Predlažem workaround:
1. Definisate problematično polje kao CHAR(14) ali onda se gubi funkcionalnost TIMESTAMP
2. Parsovati vrednost kao DATETIME
3. Ubiti nekoga iz MySQL ko je ovu promenu osmislio
4. Ubiti mene pošto sam na server stavio MySQL 4.1.14 a da nisam ni znao za ovo.
__________________
Goran Pilipović a.k.a. Ugly Fingers Bradley f.k.a. bluesman
I don't always know what I'm talking about but I know I'm right!
bluesman je offline   Odgovorite uz citat
Staro 29. 01. 2006.   #2
Petar Marić
Python Ambassador
Master
 
Avatar Petar Marić
 
Datum učlanjenja: 06.06.2005
Lokacija: Novi Sad
Poruke: 602
Hvala: 28
27 "Hvala" u 17 poruka
Petar Marić će postati "faca" uskoro
Pošaljite ICQ poruku za Petar Marić
Default

Jedan od razloga zašto uvek, ali uvek čitam changelog - još otkako sam imao "veselu" situaciju sa MS DAO API-em i Access-om 2000.
__________________
Python Ambassador of Serbia
Petar Marić je offline   Odgovorite uz citat
Staro 29. 01. 2006.   #3
bluesman
Goran Pilipović
Sir Write-a-Lot
 
Avatar bluesman
 
Datum učlanjenja: 18.05.2005
Lokacija: Beograd
Poruke: 5.450
Hvala: 288
1.247 "Hvala" u 446 poruka
bluesman je osoba koju treba slušatibluesman je osoba koju treba slušatibluesman je osoba koju treba slušatibluesman je osoba koju treba slušatibluesman je osoba koju treba slušatibluesman je osoba koju treba slušatibluesman je osoba koju treba slušatibluesman je osoba koju treba slušatibluesman je osoba koju treba slušati
Pošaljite ICQ poruku za bluesman
Default

Pa ti si naučno-istraživački radnik a mi smo samo miševi...

Ma čitam i ja često, ali ne uvek... nekada su me kolege na poslu zvale "mr. readme" pošto sam uvek čitao takve stvari... ali eto, trenutak nepažnje...

Hteo sam da učinim, na serveru je trenutno PHP 5.1.1 i mysql 4.1.14, apache 2.0.52, medjutim napravio sam "medvedju uslugu"... sada znam zasto su vecina hostova toliko intertni kada treba da se stavi nova verzija necega na server.
__________________
Goran Pilipović a.k.a. Ugly Fingers Bradley f.k.a. bluesman
I don't always know what I'm talking about but I know I'm right!
bluesman je offline   Odgovorite uz citat
Staro 29. 01. 2006.   #4
Petar Marić
Python Ambassador
Master
 
Avatar Petar Marić
 
Datum učlanjenja: 06.06.2005
Lokacija: Novi Sad
Poruke: 602
Hvala: 28
27 "Hvala" u 17 poruka
Petar Marić će postati "faca" uskoro
Pošaljite ICQ poruku za Petar Marić
Talking

<post offtopic="true">
Citat:
Originalno napisao bluesman
Pa ti si naučno-istraživački radnik a mi smo samo miševi...
Get back to your cage! Now where did I put my Little-Mad-Scientist probing tool® ...
</post>
__________________
Python Ambassador of Serbia
Petar Marić je offline   Odgovorite uz citat
Staro 29. 01. 2006.   #5
ivanhoe
Ivan Dilber
Sir Write-a-Lot
 
Avatar ivanhoe
 
Datum učlanjenja: 18.10.2005
Lokacija: Bgd
Poruke: 5.320
Hvala: 104
2.344 "Hvala" u 583 poruka
ivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svima
Pošaljite poruku preko Skype™ za ivanhoe
Default

Citat:
Originalno napisao bluesman
Predlažem workaround:
1. Definisate problematično polje kao CHAR(14) ali onda se gubi funkcionalnost TIMESTAMP
2. Parsovati vrednost kao DATETIME
3. Ubiti nekoga iz MySQL ko je ovu promenu osmislio
4. Ubiti mene pošto sam na server stavio MySQL 4.1.14 a da nisam ni znao za ovo.
ma samo koristi DATE_FORMAT() u upitu i napravi sebi format datuma koji ti treba...

inace meni je taj njihov bivsi format timestampa bio skroz glupav, nekako mi je timestamp logicno da bude vrednost u sekundama, kao unix timestamp...uglavnom je to ono sto ti treba, ili datum da ga prikazes ili sekunde da racunas nesto sa njima, a onaj YYYYMMDD format mi je bio skroz neupotrebljiv...

mada jeste jako glupo sto su tek tako promenili format, bolje da su uveli novi tip polja...ali jebga, sta je tu je, mozemo samo da pisemo svom kongresmenu :/
__________________
Leadership is the art of getting people to want to do what you know must be done.

Poslednja izmena od ivanhoe : 29. 01. 2006. u 06:20.
ivanhoe je offline   Odgovorite uz citat
Staro 29. 01. 2006.   #6
Ilija Studen
Direktor Kombinata
Invented the damn thing
 
Avatar Ilija Studen
 
Datum učlanjenja: 07.06.2005
Poruke: 2.669
Hvala: 44
119 "Hvala" u 64 poruka
Ilija Studen će postati "faca" uskoroIlija Studen će postati "faca" uskoro
Default

Primeri da se razbija backward compatibility su sve češći kad radite sa LAMPom. PHP ga je razbio prvo sa peticom, a kasnije i sa famoznim Only variables can be passed by reference. Nisam isto očekivao i od MySQLa. Oni su mi uvek delovali kao pametni momci

Ne govorom direktno o promenama i razlozima zašto su napravljene (promene su uvek na bolje sa debelim razlozima), već o načinu na koji su dodate (mi to lepo dodamo, a vi se dalje snalazite). Pitam se samo da li bi neki tamo Oracle ili Microsoft ovo smeo da dozvoli sebi? Najverovatnije bi, ali po koju cenu...

A najtužnije je što hostovi ne upgraduju jer nisu načisto šta će se desiti (da li će doći do situacije navedene gore). Lakše im je da ostave po starom ili da koriste granu gde nije došlo do "revolucionarnih" promena.

PS: Drago mi je zbog sveže platforme na Host011. Otvarate svet pun novih mogućnosti domaćim developerima

Poslednja izmena od Ilija Studen : 29. 01. 2006. u 12:33.
Ilija Studen je offline   Odgovorite uz citat
Staro 29. 01. 2006.   #7
dinke
Super Moderator
Invented the damn thing
 
Avatar dinke
 
Datum učlanjenja: 06.06.2005
Poruke: 2.371
Hvala: 370
701 "Hvala" u 194 poruka
dinke je pravi dragi kamendinke je pravi dragi kamendinke je pravi dragi kamendinke je pravi dragi kamendinke je pravi dragi kamendinke je pravi dragi kamendinke je pravi dragi kamen
Default

Za ovaj novi "feature" timestamp polja znam već neko vreme, valjda zato što praktikujem da pročitam svako novo izdanje MySQL-a (by Paul Dubois)

Ova konkretna izmena je imho krajnje nelogična, jer gotovo i da nema razlike između datetime i timestamp polja, tj.:
Kôd:
foo timestamp <=> foo datetime default CURRENT_TIMESTAMP
foo timestamp default NULL <=> foo datetime
Inače slažem se sa Ilijom glede razbijanja kompatibilnosti. PHP 6 će ako se obistine najave PHP team-a biti pravi šampion u tome.
__________________
Caught in a Web|Blogodak
With great power comes great responsibility!

Poslednja izmena od dinke : 29. 01. 2006. u 12:38.
dinke je offline   Odgovorite uz citat
Staro 31. 01. 2006.   #8
ivanhoe
Ivan Dilber
Sir Write-a-Lot
 
Avatar ivanhoe
 
Datum učlanjenja: 18.10.2005
Lokacija: Bgd
Poruke: 5.320
Hvala: 104
2.344 "Hvala" u 583 poruka
ivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svima
Pošaljite poruku preko Skype™ za ivanhoe
Default

Citat:
Originalno napisao dinke
Kôd:
foo timestamp <=> foo datetime default CURRENT_TIMESTAMP
foo timestamp default NULL <=> foo datetime

meni na 4.1.9 ne dozvoljava da setujem default za datetime da bude CURRENT_TIMESTAMP ? Kaze da je to invalid default value (myISAM tabela)

od koje verzije su to podrzali?
__________________
Leadership is the art of getting people to want to do what you know must be done.
ivanhoe je offline   Odgovorite uz citat
Staro 31. 01. 2006.   #9
dinke
Super Moderator
Invented the damn thing
 
Avatar dinke
 
Datum učlanjenja: 06.06.2005
Poruke: 2.371
Hvala: 370
701 "Hvala" u 194 poruka
dinke je pravi dragi kamendinke je pravi dragi kamendinke je pravi dragi kamendinke je pravi dragi kamendinke je pravi dragi kamendinke je pravi dragi kamendinke je pravi dragi kamen
Default

Od nijedne To sam stavio više ilustracije radi, tj. da je timestamp polje (od MySQL >= 4.1) istog oblika kao datetime s tim što je default vrednost CURRENT_TIMESTAMP (tj. prilikom update-a po defaultu se setuje na trenutni timestamp).

Inače, za timestamp je moguće to definisati kao recimo sa:
Kôd:
foo timestamp on update CURRENT_TIMESTAMP default CURRENT_TIMESTAMP
__________________
Caught in a Web|Blogodak
With great power comes great responsibility!
dinke je offline   Odgovorite uz citat
Staro 31. 01. 2006.   #10
ivanhoe
Ivan Dilber
Sir Write-a-Lot
 
Avatar ivanhoe
 
Datum učlanjenja: 18.10.2005
Lokacija: Bgd
Poruke: 5.320
Hvala: 104
2.344 "Hvala" u 583 poruka
ivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svima
Pošaljite poruku preko Skype™ za ivanhoe
Default

a tooo...
ma dobro za timestamp je to default ponasanje, sem kad ih je vise u istoj tabeli...

ali sam ja pogresno shvatio kad si rekao da su timestamp i datetime postali skoro isti...posto je ocigledno timestamp i dalje neophodan ako zelis da ti se vreme poslednje izmene automatski azurira, datetime to ne ume...
__________________
Leadership is the art of getting people to want to do what you know must be done.
ivanhoe je offline   Odgovorite uz citat
Odgovori


Alati teme
Način prikaza

Pravila pisanja
Možete ne započinjati nove teme
Možete ne slati odgovore
Možete ne slati priloge
Možete ne izmeniti svoje poruke
vB kôd je Uključen
Smajliji su Uključen
[IMG] kod je Uključen
HTML kôd je Isključen
Pogledajte forum

Slične teme
Tema Početna poruka teme Forum Odgovori Poslednja poruka
MYSQL: Kako struktuirati tabele vezano za broj prikaza nekog teksta na stranici? mb_sa SQL baze podataka - Sponzor: Baze-Podataka.net 6 03. 03. 2009. 09:16
Kontrolisanje prikaza baner-a GaVrA Marketing i SEO 4 11. 11. 2008. 08:38
Podesavanje prikaza naslovnice mastika Web aplikacije, web servisi i software 2 22. 07. 2008. 23:07
datum i mysql (datetime, date, timestamp) staseprimate Sva početnička pitanja 10 17. 12. 2007. 04:39


Vreme je GMT +2. Trenutno vreme je 17:21.


Powered by vBulletin® Verzija 3.6.8
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
Copyright © DevProTalk. All Rights Reserved.
Mišljenja, saveti, izjave, ponude ili druge informacije ili sadržaji nastali na Sajtu su vlasništvo onoga ko ih je kreirao, a ne DevProTalk.com, tako da ne morate da se oslanjate na njih.
Autori poruka su jedini odgovorni za ovakve sadržaje. DevProTalk.com ne garantuje tačnost, kompletnost ili upotrebnu vrednost informacija, stavova, saveta ili datih izjava. Ne postoje uslovi pod kojima bi mi bili odgovorni za štetu ili gubitak koji je posledica bilo čijeg oslanjanja na nepouzdane informacije, ili bilo kakve informacije nastale kroz komunikaciju između registrovanih članova.
Web sajt može sadržavati linkove na druge web sajtove na Internetu ili neke druge sadržaje. Ne kontrolišemo niti podržavamo te druge web sajtove, niti smo pregledali bilo kakve sadržaje na takvim sajtovima. Mi nećemo biti odgovorni za legalnost, tačnost ili prikladnost bilo kog sadržaja, oglasa, proizvoda, usluga ili informacije lociranim na ili distribuiranih kroz druge web sajtove, niti za bilo kakvu štetu nastalu kao posledica takvih informacija. DevProTalk.com drži i čuva druga prava vlasništva na web sajtu. Web sajt sadrže materijale zaštićene copyright-om, zaštitne znakove i druge informacije o pravu vlasništva ili softver. Članovi mogu poslatu informacije zaštićene pravima vlasništva njihovih nosilaca i ona ostaju zaštićena bez obzira da li su oni koji prenose te informacije to naveli ili ne. Osim informacija koje su u javnom vlasništvu ili za koje dobijete dozvolu, nemate pravo da kopirate, modifikujete ili na bilo koji način menjate, objavljujete, prenosite, distribuirate, izvršavate, prikazujete ili prodajte bilo koju informaciju zaštićenu pravima vlasništva. Slanjem informacija ili sadržaja na bilo koji deo DevProTalk.com, Vi automatski dozvoljavate i predstavljate garanciju da imate pravo da dozvolite DevProTalk.com ili članovima DevProTalk.com bespovratnu, kontinualnu, neograničenu, globalnu dozvolu da koriste, kopiraju, izvršavaju, prikazuju i distribuiraju takve informacije i sadržaje i da iz takvih sadžaja koriste bilo koji deo u bilo koje svrhe, kao i pravo i dozvolu da koriste gore navedene sadržaje. Svi zaštitni znakovi (trademarks), logotipi, oznake usluga, firme ili imena proizvoda koji se pominju na ovom web sajtu su vlasništvo kojim raspolažu njihovi vlasnici.