• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

Problem Mysql Python

Object Storage Arubacloud
0 głosów
272 wizyt
pytanie zadane 13 kwietnia 2017 w Python przez niezalogowany

Witam, mam zainstalowany mysql do pythona. Mam kodzik:

#-*- coding: utf-8 -*-
import MySQLdb


import MySQLdb
db = MySQLdb.connect(user='cpp', passwd='cpp', db='cpp',
                             host='127.0.0.1', port=3306)
                   
cur = db.cursor();
	cur.execute("SELECT * FROM kolejka");

	for row in cur.fetchall():
		a = str(row[0])
		print a

db.close()

On wypisuje wszystkie rekordy z tabeli kolejka. Jest to kolumna id. I teraz niewiem jak pobrać dosłownie jednego rekorda, a nie wszystkie z tabeli. W SQL to chciałbym aby było:

SELECT * FROM wys WHERE id=[tutaj ta wartość a]

I wtedy pobrać row[1] właśnie z tego zapytania.

Pozdrawiam i z góry dzięki za każdą pomoc.

1 odpowiedź

0 głosów
odpowiedź 13 kwietnia 2017 przez adrian17 Ekspert (344,860 p.)
wybrane 14 kwietnia 2017
 
Najlepsza
cur.execute("SELECT * FROM kolejka WHERE id=%s", (123,));

 

komentarz 14 kwietnia 2017 przez adrian17 Ekspert (344,860 p.)
int(tekst)
komentarz 14 kwietnia 2017 przez niezalogowany

Ej jeszcze, czemu jak mam taki kod:

#-*- coding: utf-8 -*-
print 'KACPER PROGRAMMING SYSTEM V. 0.1 - ENGINE'
import MySQLdb
import os
import linecache
db = MySQLdb.connect(user='cpp', passwd='cpp', db='cpp',
                             host='127.0.0.1', port=3306)
                   
cur = db.cursor();
cura = db.cursor();
while 1==1:
	cur.execute("SELECT * FROM kolejka")
	for row in cur.fetchall():
		a = str(row[0])
		b = row[1]
		cura.execute("SELECT kod FROM wys WHERE id = %s", (a,))
		rzecz = cura.fetchone()[0]
		plik = open('z.cpp', 'w')
		plik.write(rzecz)
		plik.close()
		cura.execute("SELECT limity FROM zadania WHERE skrot = %s", (b,))
		lim = cura.fetchone()[0]
		cura.execute("SELECT testy FROM zadania WHERE skrot = %s", (b,))
		tes = cura.fetchone()[0]
		plik = open('wej.in', 'w')
		q = b+" "+str(tes)+" "+lim
		plik.write(q)
		plik.close();
		os.system("./spr < wej.in")
		plik = open('wynikz.txt')
		try:
			tekst = plik.read()
		finally:
			plik.close()
		wiersz = linecache.getline('wynikz.txt', tes)
		cura.execute("UPDATE wys SET punkty=%s WHERE id=%s", (str(wiersz), a,))
		os.system("rm z.cpp")
		cura.execute("DELETE FROM kolejka WHERE id = %s", (a,))
		db.commit()

db.close()

To, jak są jakieś rekordy w tabelii kolejka, to wszystkie prawda "obrabia", i je usuwa, ale jak jest odpalony i dodam to już nowych nie łapie, trzeba restart programu.

komentarz 14 kwietnia 2017 przez adrian17 Ekspert (344,860 p.)
Może przez transakcje. Potestuj commit().
komentarz 14 kwietnia 2017 przez niezalogowany
edycja 14 kwietnia 2017

A o co chodzi z tymi transakcjami? Nie widzę, sensu dlaczego to nie działa.

EDIT: I jeszcze te int, to wywala błąd:

ValueError: invalid literal for int() with base 10: ''

 

komentarz 14 kwietnia 2017 przez adrian17 Ekspert (344,860 p.)
Twoje "ID" jest pustym stringiem - nic dziwnego, że nie daje się skonwertować na inta, nie?

Z mojej strony to ostatnia odpowiedź w tym wątku.

Podobne pytania

0 głosów
1 odpowiedź 139 wizyt
pytanie zadane 16 października 2022 w Python przez benny13 Obywatel (1,150 p.)
+1 głos
1 odpowiedź 1,395 wizyt
0 głosów
1 odpowiedź 525 wizyt
pytanie zadane 1 stycznia 2021 w Python przez Hacker4300.exe Użytkownik (650 p.)

92,576 zapytań

141,426 odpowiedzi

319,652 komentarzy

61,961 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...