Python 2.6.6 ja SQL SELECT JA INSERT

Eli ihan SQL-perusteissa ollaan, mutta Pythonilla koskaan toistaiseksi tietokantoja käsitellyt, ja palvelimella on käytössä Python 2.6.6. Voisiko joku pistää malliksi, miten tietokannasta saa haettua ensinnäkin Selectillä kyseisessä Python-versiossa tietueita, ja miten niitä saa INSERTin kanssa sinne lisätyksi.

Lisäksi Select COUNT(*) FROM Table, tai vastaava Python koodi, mistä saisi tietueiden lukumäärän int-tyyppisenä arvona ulostulona.

10

892

    Vastaukset

    Anonyymi (Kirjaudu / Rekisteröidy)
    5000
    • Turbo-Urpo1

      Olen jakanut tämän ohjeen kolmeen (3) erilliseen tiedostoon, joista ensimmäinen tässä.

      Tässä kuvassa on esimerkki, jossa sattuman varaisesti valitaan automerkki ja sille hinta, lisättäväksi "cars" tietokantaan. Tämän tarkoitus on selventää asiaa kuinka muuttujan sisältönä oleva arvo listään tietokantaan, tämähän on pakko osata jokaisen.

      https://i.postimg.cc/v8XT2kxR/Valinta-004.png

      En laita tähän tuota koodia, kun se niin helposti saa aikaan koko viestin poiston. Joten menettele seuraavasti:

      Kirjoita koodi, ja tallenna se [ insert-table.py ] nimellä
      Anna suoritusoikeudet [ chmod x insert-table.py ]

      Laitan tuossa myöhemin vielä kahden tiedoston koodit, joista toinen luo [ testi ] tietokannan ja lisää siihen tässä tarvittavan [ cars ] taulukon.

      • Turbo-Urpo1

        Huomaa että et voi sitä suorittaa vielä, koska tietokantaa ei ole olemassa, mutta kun se tässä myöhemin tulee, suoritat sen näin:

        ./insert-table.py

        Ja tuohan edellyttää sitä että tiedostolle on annettu suoritusoikeudet

        chmod x insert-table.py

        Ja nämä käskyt suoritat siinä kansiossa missä tiedostotkin ovat, tai muutat polut siaintia vastaaviksi. Ilman suoritusoikeuksia python tiedosto ajetaan tulkin mukana näin:

        python ./insert-table.py

        No se siitä.


    • Turbo-Urpo1
      • Turbo-Urpo1

        Tuohon olisi pitänyt yhdistää tuo COUNT, mutta nyt tässä erikseen. Eli kuvan koodissa listataan Audin merkkien määrä tietokannassa, ja kaikkien merkintöjen määrä.
        https://i.postimg.cc/Z0kPCqkQ/Valinta-008.png

        Huomasithan että voit suorittaa tuon ensimäisen vaikka kuinka monta kertaa ja aina tulee uusi arvottu automerkki listaan lisää.


      • Turbo-Urpo1
        Turbo-Urpo1 kirjoitti:

        Tuohon olisi pitänyt yhdistää tuo COUNT, mutta nyt tässä erikseen. Eli kuvan koodissa listataan Audin merkkien määrä tietokannassa, ja kaikkien merkintöjen määrä.
        https://i.postimg.cc/Z0kPCqkQ/Valinta-008.png

        Huomasithan että voit suorittaa tuon ensimäisen vaikka kuinka monta kertaa ja aina tulee uusi arvottu automerkki listaan lisää.

        Tässä vielä on laskettu montako prosentia Audin osuus on listatuista:
        https://i.postimg.cc/KvJL6QjV/Valinta-009.png


    • Turbo-Urpo1

      Ja tässä on tuo viimmeinen osa, jossa se tietokanta pistetään alulle.

      https://i.postimg.cc/XYNYf8Yj/Valinta-007.png

      Koreilemattoman yksinkertaista, vai mitä.

      Minä käytin näitä tiedostonimiä,
      create-table.py
      insert-table.py
      select-table.py

      Luvettelin nuo mikäli näihin joutuu jatkossa viittaamaan.

    • tossajotain

      Tarvitsee jonkun MySQL-kikkareen Pythoniin, esimerkiksi PyMySQL:n.

      Sitten aukaistaan tietokanta:

      conn=pymysql.connect(host=palvelin,port=3306,user=käyttäjä,passwd=salasana,db=tietokanta)

      Muodostetaan sql-lause inserttiin, jossa laitetaan tauluun "nimet" nimi "Pertti".

      lisattavanimi="Pertti"
      sql="INSERT INTO nimet(nimi) VALUES ('{0}');".format(lisattavanimi)

      Suoritetaan sql:

      cur=conn.cursor()
      cur.execute(sql)

      Tarkastetaan onnistuiko:

      if not cur.lastrowid:
          ->epäonnistui

      Lopuksi commit ja sulkemiset:

      conn.commit()
      cur.close()
      conn.close()

      Hakeminen kannasta, avaukset ja sulkemiset kuten edellisessä, mutta sql-lause:

      haettavanimi="Pertti"
      sql = "SELECT * FROM nimet WHERE nimi='{0}';".format(haettavanimi)

      cur=conn.cursor()
      cur.execute(sql)

      Jos löytyi yhtään:

      if cur.rowcount>0:
          haetut=list(cur.fetchall())

      Tämän jälkeen kannasta haetut rivit pitäisi olla listalla "haetut".

      Esimerkkejä: https://www.programcreek.com/python/example/53260/pymysql.connect

      • f-stringit

        Tämä kommentti ei auta aloittajaa yhtään, mutta Pythonin versiosta 3.6 lähtien on voitu käyttää ns. f-stringejä, joilla esimerkiksi noiden sql-lauseiden muodostaminen muuttuu hieman kätevämmäksi.

        Esimerkiksi:

        sql="INSERT INTO nimet(nimi) VALUES ('{0}');".format(lisattavanimi)

        Voidaan kirjoittaa lyhyemmin muodossa:

        sql2=f"INSERT INTO nimet(nimi) VALUES ('{lisattavanimi}');"

        Lisää aiheesta https://cito.github.io/blog/f-strings/


    • No joo, kiitti paljon vastanneille! Ongelmaksi koitui, että mun verkkoisännällä ei ollut mysli-moduulia tukena Pythonissa. Toteutin verkkosovellukseni PHP:llä lopulta. Julkaisin Palindromikoneeni ensimmäisen version yleisölle, missä oli Palindromin tarkastus ja muut härpäkkeet toteutettu Pythonilla, mutta lisättyäni tietokannan tavoitteena kerätä Suomen laajin Palindromitietokanta, toteutin lopulta kaiken PHP:llä, koska verkkoisäntäni tukee sitä pääsääntöisesti.

      Suora osoite sovellukseeni on https:\\www.tuntikirjuri.net/Palindromikone

      Meille pimeän puolen pitkän linjan nettikäyttäjille, joilla ei ole mitään elämää netin ulkopuolella, lisää haastetta, eikö?

      • Turbo-Urpo1

        No joo, PHP:lla tuon olisin minäkin tehnyt, ja kun sivusi muuten on WP-päällä oikein hyvin sopii senkin vuoksi. Olisinpa saattanut yrittää käyttää palindromityyli.css tyylitiedoston sijasta WP:een style.css tiedostoakin, jotta olisi yhtenevän näköinen kotisivusi kanssa.

        Kommentoin oikolukematta, jos julkaset, korjaa virheet ennen näytille panoa.


    Ketjusta on poistettu 0 sääntöjenvastaista viestiä.

    Luetuimmat keskustelut

    1. Saisinpa halata sinua joka päivä

      ja kertoa miten paljon sinusta välitän. Vaikka olisi jommalla kummalla huono päivä, väsynyt päivä tai kiireinen päivä, a
      Ikävä
      50
      5839
    2. Me työeläkeläiset äänestämme SDP:tä

      SDP on luonut koko työeläkejärjestelmän, jonka hedelmistä saamme nyt nauttia. Kansaneläkelaitos on Maalaisliiton tekele,
      Maailman menoa
      44
      4382
    3. Nykymiehet odottaa, että nainen lähestyy?

      Perus luonnonlaki menee päinvastoin! Oletko nähnyt luontodokkaria jossa naaraat juoksee uroksien perässä??? 🦁🫎🦍🐒🦦�
      Ikävä
      148
      4029
    4. Kolmen tuiki tavallisen demariahdistelijan nimet julki

      Nyt tiedetään ketkä kolme oli niissä niin tavanomaisissa demarin jokapäiväisissä askareissa avustajia ahdistelemassa. K
      Maailman menoa
      91
      3650
    5. Sannahan laski sähkön ALV:n 10 prosenttiin, Riikka runnoi 25,5 %:iin

      Tässäkin nähdään kumpi on Suomen kansan puolella, ja kumpi omaa vastaan. Putinistipersuille Suomen kansa tulee aina vii
      Maailman menoa
      71
      2879
    6. Kansalaispalkka ja maksuton joukkoliikenne

      Noilla pienillä parannuksilla saadaan Suomesta taas hitusen parempi paikka peruskansalaiselle, joka elää ekologisesti ja
      Maailman menoa
      106
      2517
    7. Eikö tunnukin kamalalta, kun en

      anna periksi vaikka parhaasi olet tehnyt antaaksesi täystyrmäyksen? Ja kyllähän minä monta iskua olen saanut ja maannut
      Ikävä
      42
      1976
    8. Antti Lindtman: "Ainahan kaikenlaisia huhuja liikkuu"

      Näin hän siis vastaa SDP:n häirintäkohuun, väistelee vastuutaan Juttuhan on niin, että Lindtman ja Tuppurainen on tasan
      Maailman menoa
      56
      1836
    9. Muistattekos kun kaupassa piti pyytää tavarat myyjältä

      Edes kahvipakettia ei saanut itse valita, vaan myyjä nouti sen hyllystä tiskille. Jos osti jauhelihaa, niin se jauhettii
      Maailman menoa
      237
      1702
    10. Kenen juontajan pitäisi voittaa tänään Kultainen Venla? Ehdolla Pimiä, Holma ja Vaaherkumpu

      Kultainen Venla gaalassa jaetaan tänään tv-alan palkintoja. Yksi suosituimmista kategorioista on Juontaja. Vappu Pimiä
      Suomalaiset julkkikset
      34
      1482
    Aihe