DevProTalk

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


Idite nazad   DevProTalk > DevProTalk > Sva početnička pitanja
Želite da se reklamirate ekskluzivno na ovoj poziciji? Javite se

Sva početnička pitanja Sva početnička pitanja bi trebala da se postavljaju u ovom forumu, a ako se pretvori u kvalitetnu diskusiju interesantnu svima - prebacićemo je u odgovarajući forum. Molimo "znalce" da ne omalovažavaju početnike, ako žele da pomognu svi ćemo biti zahvalni, ako ne žele, neka preskoče ovaj forum.

Odgovori
 
Alati teme Način prikaza
Staro 03. 04. 2008.   #1
misko_
profesionalac
Qualified
 
Datum učlanjenja: 22.09.2007
Lokacija: Split
Poruke: 111
Hvala: 8
39 "Hvala" u 10 poruka
misko_ is on a distinguished road
Unhappy Pomoc oko Encoding

Cao,

Na php stranici koristim
HTML kôd:
    <meta http-equiv="Content-Type" content="text/html; charset=charset=utf-8" /> 
Kada citam podatke iz baze koji imaju slova šđčćž, umijesto njih dobijem upitnike.

Otprilike kuzim u cemu je problem ali imaju neke stvari poje mi nisu najjasnije pa bih molio za pomoc.

Za ta polja i bazu mi pod "Collation" stoji "latin1_swedish_ci". Mislim da je ovdije zapravo problem, smatram da kada bi umijesto "latin1_swedish_ci" stajalo "utf_bin" da taj problem ne bi postojao. Da li sam upravu ???

Na glavnoj strani od phpMyAdmina mi stoji:
Citat:
MySQL charset: UTF-8 Unicode (utf8)
MySQL connection collation: utf8_unicode_ci
Ne kuzim cemu ovo sluzi, da li mi netko moze objasniti?
Da li sa nekom promjenom ovdje mogu rijesiti svoj problem ?

Da li postoji neki nacin da ja kada pokupim string iz baze da ga prebacim iz "latin1_swedish_ci" u "utf-8" ?
Probavao sam sa http://de.php.net/utf8_encode , http://de3.php.net/mb_convert_encoding ali nisam uspio, iako nisam siguran da li je to uopce moguce ?

Koje postavke vi koristite kod MySQL-a za polja(baze) koja imaju "šđžćč" slova i sto koristite za charset unutar meta taga ?

Jedno od rijesenja koje sam nasao je da prebacim cijelu bazu u utf8 objasnjeno je na http://drupal.org/node/62258 ili http://www.oreillynet.com/onlamp/blo..._latin1_t.html samo nisam siguran da li ce mi to uopce pomoci.

Sto bi mi vi savjetovali ?

P.S. neki linkovi koje sam pronasao da su korisni
http://www.joelonsoftware.com/articles/Unicode.html
http://www-atm.physics.ox.ac.uk/user/iwi/charmap.html
http://www.i18nguy.com/unicode/codepages.html#msftdos

Hvala
misko_ je offline   Odgovorite uz citat
Staro 03. 04. 2008.   #2
mileusna
Super Moderator
Knowledge base
 
Datum učlanjenja: 21.03.2006
Lokacija: Kragujevac
Poruke: 1.878
Hvala: 291
1.345 "Hvala" u 355 poruka
mileusna je jednostavno dobarmileusna je jednostavno dobarmileusna je jednostavno dobarmileusna je jednostavno dobarmileusna je jednostavno dobarmileusna je jednostavno dobarmileusna je jednostavno dobarmileusna je jednostavno dobarmileusna je jednostavno dobarmileusna je jednostavno dobar
Default

Citat:
Originalno napisao misko_ Pogledajte poruku
Za ta polja i bazu mi pod "Collation" stoji "latin1_swedish_ci". Mislim da je ovdije zapravo problem, smatram da kada bi umijesto "latin1_swedish_ci" stajalo "utf_bin" da taj problem ne bi postojao. Da li sam upravu ???
Da, definitivno ti polje u bazi mora biti utf_* da bi cela stvar funkcionisala.

Citat:
MySQL charset: UTF-8 Unicode (utf8)
MySQL connection collation: utf8_unicode_ci
Ne kuzim cemu ovo sluzi, da li mi netko moze objasniti?
Da li sa nekom promjenom ovdje mogu rijesiti svoj problem ?
Određuješ charset za MySQL konekciju, upravo da bi se uskladio encoding između baze i SQL klijenta, u ovom slučaju phpMyAdmina, kako bi svi karakteri bili pravilo enkodirani i da ne bi došlo do "brljanja".

Praksa je da ovo radiš i iz svojih PHP skriptova nakon kreiranja MySQL konekcije:
Kôd:
mysql_query("SET NAMES utf8");
mysql_query("SET collation_connection='utf8_general_ci'");
Citat:
Da li postoji neki nacin da ja kada pokupim string iz baze da ga prebacim iz "latin1_swedish_ci" u "utf-8" ?
Pogledaj iconv funkciju, to bi trebalo da ti završi posao.

Citat:
Koje postavke vi koristite kod MySQL-a za polja(baze) koja imaju "šđžćč" slova i sto koristite za charset unutar meta taga ?
Kôd:
<meta http-equiv='Content-Type' content='text/html; charset=utf-8' />
U svakom slučaju UTF-8 je najbolje rešenje i ne treba se zanasiti sa starijim kodnim rasporedima.
mileusna je offline   Odgovorite uz citat
"Hvala" mileusna za poruku:
Staro 12. 04. 2008.   #3
misko_
profesionalac
Qualified
 
Datum učlanjenja: 22.09.2007
Lokacija: Split
Poruke: 111
Hvala: 8
39 "Hvala" u 10 poruka
misko_ is on a distinguished road
Thumbs up Rijeseno i hvala

NIje mi se dalo zezati sa iconv funkciju, nego sam cijelu bazu(sva polja, tablice, i samo zabtu prebacio u utf8) za to sam se pomogao kod(nije mi se dalo rucno)

PHP kôd:
<?php
$db 
mysqli_connect('localhost','username','password''db');
if(
mysqli_connect_errno())

    echo 
"Cannot connect to the database - incorrect details";
}

$sql 'SHOW TABLES';
if ( !( 
$result $db->query$sql ) ) ) {
       echo 
'<span style="color: red;">Get SHOW TABLE - SQL Error: <br>' "</span>\n";
    }

   
while ( 
$tables $result->fetch_row() ) {
    echo 
$tables[0];
# Loop through all tables in this database
   
$table $tables[key($tables)];
  
   if ( !( 
$result2 $db->query("ALTER TABLE ".$table." COLLATE utf8_general_ci") ) ) {
        echo 
'<span style="color: red;">UTF SET - SQL Error: <br>' "</span>\n";
     
          break;
           }
  
   print 
"$table changed to UTF-8 successfully.<br>\n";

   
# Now loop through all the fields within this table
   
if ( !($result2 $db->query("SHOW COLUMNS FROM ".$table) ) ) {
          echo 
'<span style="color: red;">Get Table Columns Query - SQL Error: <br>' "</span>\n";
     
          break;
           }

   while ( 
$column $result2->fetch_assoc() )
   {
      
$field_name $column['Field'];
      
$field_type $column['Type'];
     
      
# Change text based fields
      
$skipped_field_types = array('char''text''enum''set');
     
      foreach ( 
$skipped_field_types as $type )
      {        
         if ( 
strpos($field_type$type) !== false )
         {
            
$sql4 "ALTER TABLE $table CHANGE `$field_name` `$field_name$field_type CHARACTER SET utf8 COLLATE utf8_general_ci";
            
$result4 $db->query($sql4);

            echo 
"---- $field_name changed to UTF-8 successfully.<br>\n";
         }
      }
   }
   echo 
"<hr>\n";
}
$result->free();
$result2->free();
$result4->free();
?>
koji sam pronasao medu komentarima na http://dev.mysql.com/doc/refman/5.0/...onnection.html

jos bi nadodao da stari unosi koji su bili uneseni u "latin1_swedish_ci" nisu prikazivali neka slova kako treba, pa sam to rucne prebacio(jer ih nije bilo puno), ali sma siguran da bi se i za to dala napisati kakva skripta...
misko_ 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
IPTC encoding ivanhoe PHP 2 14. 06. 2010. 13:02
Encoding problemi robi-bobi Obaveštenja, predlozi i pitanja 6 24. 01. 2009. 17:04
Encoding XMLa na WordPressu blogowski Sva početnička pitanja 29 31. 10. 2008. 13:17
[MSSQL] Eksport u xml, utf-8 encoding nenana SQL baze podataka - Sponzor: Baze-Podataka.net 8 10. 09. 2008. 16:02
Nepoznat encoding u dump fajlu Peca SQL baze podataka - Sponzor: Baze-Podataka.net 0 01. 11. 2007. 22:05


Vreme je GMT +2. Trenutno vreme je 16: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.