jeps. IHan alkuun pitää sanoa että olen totaalinen aloittelija PHP:n kanssa, oon koodannu enemmän ASP:illa (eli jotain käsitystä siitä mitä pitäisi tapahtua). Sain justiin asennettua serverille PHP:n ja MySQL:n (kun nyt piti sitten saada sivut tehtyä PHP:llä) ja tehtyä MySQL:ään tietokannan tietueineen.
Pitäis tehdä formi jolla vois submittaa tietokantaan, mutta kun koitan tuota mitä oon tehny niin MySQL:n admin sanoo ettei siellä ole yhtäkään riviä.
Tän verran oon nyt saanu pähkäiltyä:
PHP ja MySQL - INSERT INTO ongelmia
8
1897
Vastaukset
- se ok, lisää hihnalla
tuo äskönen ratkes kun laitoin kaikki tietueen palstat SQL:ään:
tämän sijasta
$SQL = "INSERT INTO news(iDate,iTime,iAuthor,iPic,iHeader,iText,iMemo) VALUES('$date','$time','$auth','$pic','$head','$text','$memo')";
laitoin
$SQL = "INSERT INTO news(ID,iDate,iTime,iAuthor,iPic,iHeader,iText,iMemo) VALUES('1','$date','$time','$auth','$pic','$head','$text','$memo')";
Missä tuo ID on mediumint(8), not null, auto increment, unsigned. Ongelma on nyt siinä että se pitäisi saada se numero juoksemaan automaattisesti kun sinne tiatokantaan tyrkkää dataa, eikä niin että se muutetaan koodissa, vai onko se edes mahdollista? Eikös auto increment justiin tarkota sitä et se nostaa sitä automaagisesti? hmpf.. on tääkin.
Elikkä, jos olis jotain ratkasua tuohon niin olis taas paljon viisaampi.. siis miten sais tuon nomeron juokseen... vai pitääkö se tosiaan ensin käydä lukemassa tietokannasta et mikä se on ja sit lisätä siihen yksi niin että se toimii? o.O- flap
laita vaikka NULL
$SQL = "INSERT INTO news(ID,iDate,iTime,iAuthor,iPic,iHeader,iText,iMemo) VALUES(NULL,'$date','$time','$auth','$pic','$head','$text','$memo')"; - noobie
flap kirjoitti:
laita vaikka NULL
$SQL = "INSERT INTO news(ID,iDate,iTime,iAuthor,iPic,iHeader,iText,iMemo) VALUES(NULL,'$date','$time','$auth','$pic','$head','$text','$memo')";kun siinä kuitenkin *pitäisi* olla se juokseva numero siellä tietokannassa....
Ratkaisin sen kuitenkin jo toisella tavalla, eli ensin lukemalla jo olemassaolevan ja lisäämällä siihen yhden. ah, niin aataminaikaista. - mysli uuno
noobie kirjoitti:
kun siinä kuitenkin *pitäisi* olla se juokseva numero siellä tietokannassa....
Ratkaisin sen kuitenkin jo toisella tavalla, eli ensin lukemalla jo olemassaolevan ja lisäämällä siihen yhden. ah, niin aataminaikaista.Yleensä tällaisissa tapauksissa luodaan sekvenssi ja annetaan id:lle oletusarvoksi sekvenssin seuraava merkki. Eikö tällainen onnistu mysql:ssä?
Tuolla metodillasi, jossa luet, lasket ja kirjoitat saattaa tulla äkkiä ongelmia päällekkäisten kyselyjen takia. Itse asiassa päällekkäiset kyselyt taitavat rikkoa kantasi rakenteen heti. - flap
noobie kirjoitti:
kun siinä kuitenkin *pitäisi* olla se juokseva numero siellä tietokannassa....
Ratkaisin sen kuitenkin jo toisella tavalla, eli ensin lukemalla jo olemassaolevan ja lisäämällä siihen yhden. ah, niin aataminaikaista.jos sulla on se id auto_increment niin kyllä se määrää sen arvon siihen automaagisesti jos laitat arvoksi null.. passaa kokeilla..
- noobie
flap kirjoitti:
jos sulla on se id auto_increment niin kyllä se määrää sen arvon siihen automaagisesti jos laitat arvoksi null.. passaa kokeilla..
Kiitos tuhannesti vinkistä, se toimi.
Nyt mulla olis lisää ongelmia =P
Tällanen koodinpätkä tällä kertaa:
if ($_POST['delete'] == "pass") {
$vID = $_POST['NewsID'];
?> - noobie
noobie kirjoitti:
Kiitos tuhannesti vinkistä, se toimi.
Nyt mulla olis lisää ongelmia =P
Tällanen koodinpätkä tällä kertaa:
if ($_POST['delete'] == "pass") {
$vID = $_POST['NewsID'];
?>Otin tähden pois SQL-lauseesta ja nyt se toimii.
ennen
$SQL = "DELETE * FROM news WHERE ID = '$vID'";
jälkeen
$SQL = "DELETE FROM news WHERE ID = '$vID'"; - ---------
noobie kirjoitti:
Otin tähden pois SQL-lauseesta ja nyt se toimii.
ennen
$SQL = "DELETE * FROM news WHERE ID = '$vID'";
jälkeen
$SQL = "DELETE FROM news WHERE ID = '$vID'";Toimii noin, mutta missäs se tietoturva on?
Laita syötteet http://fi.php.net/manual/en/function.mysql-real-escape-string.php läpi ellet muuten tarkasta niit.
Mitähän tapahtuu jos $vID saakin tämmösen arvon ' AND ID > '0
Poistetaan ID joka on tyhjä ja lisäksi kaikki joiden ID on suurempa kuin 0, siis kaikki.
Ja vinkkinä, että kun includetat niin sen voi tehdä suoraan eikä tartte laittaa mitään ylimääräsiä
Ja selvyyden vuoksi kannattaa kannattaisi tehdä hieman toisin tuo. Otat yhteyden tietokantaan ennen if/else juttuja ja suljet senjälkeen näin ei tartte tupla includeita.
Lukaseppas http://keskustelu.suomi24.fi/show.fcgi?category=108&conference=500000000000005&posting=22000000016627783 varsinkin se viiminen linkki.
Ketjusta on poistettu 0 sääntöjenvastaista viestiä.
Luetuimmat keskustelut
Riikan kukkaronnyöri on umpisolmussa
Kulutus ei lähde liikkeelle, koska kansalaiset eivät usko, että: – työpaikka säilyy – tulot eivät romahda – talous ei h452929Jos vedetään mutkat suoraksi?
Niin kumpaan ryhmään kuulut? A) Niihin, jotka menevät edellä ja tekevät? Vai B) Niihin, jotka kulkevat perässä ja ar1062701Tanskan malli perustuu korkeaan ansioturvaan
Ja vahvoihin työllisyys- ja kotoutumispalveluihin. Suomessa Riikka on leikannut juuri näitä: palkkatukea, työttömyysturv362419- 322014
Vain vasemmistolaiset ovat aitoja suomalaisia
Esimerkiksi persut ovat ulkomaalaisen pääomasijoittajan edunvalvojia, eivät auta köyhiä suomalaisia.501918Anteeksipyyntöni
Jätän tähän anteeksipyyntöni sinulle, koska en voi sanoa sitä missään muuallakaan. Pyydän anteeksi, jos purkamani tuska151529- 321473
Sydämeni valtiaalle
En täältä aio asioita kysellä. Haluan tuoda tiedoksesi, että pohjimmiltani en ihmisiä tahdo satuttaa ja ajattelen muiden1051225- 1771193
En vain unohda
Sitä miten rakastuneesti olet minua katsonut. Oliko tunteet liian suuria että niistä olisi voinut puhua.731050