test_1.py 2.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  1. import sqlite3 as sq
  2. def test_1():
  3. with sq.connect("saper.db") as con:
  4. cur = con.cursor() # Cursor
  5. # cur.execute("DROP TABLE IF EXISTS users")
  6. cur.execute("""CREATE TABLE IF NOT EXISTS users (
  7. user_id INTEGER PRIMARY KEY AUTOINCREMENT,
  8. name TEXT NOT NULL,
  9. sex INTEGER NOT NULL DEFAULT 1,
  10. old INTEGER,
  11. score INTEGER
  12. )""")
  13. def saper_db():
  14. with sq.connect('saper.db') as con:
  15. cur = con.cursor()
  16. cur.execute("""CREATE TABLE IF NOT EXISTS users (
  17. name TEXT,
  18. sex INTEGER,
  19. old INTEGER,
  20. score INTEGER
  21. )""")
  22. cur.execute('INSERT INTO users VALUES ("Михаил", 1, 22, 100)')
  23. cur.execute('INSERT INTO users VALUES ("Яна", 2, 24, 830)')
  24. cur.execute('INSERT INTO users VALUES ("Федор", 1, 32, 764)')
  25. cur.execute("""CREATE TABLE IF NOT EXISTS games (
  26. user_id INTEGER,
  27. score INTEGER,
  28. time INTEGER
  29. )""")
  30. for i in range(1, 8):
  31. cur.execute(f'INSERT INTO games VALUES ({i}, {i*200}, {i*10000})')
  32. con.commit()
  33. cur.execute("SELECT * FROM users WHERE score > 100 ORDER BY score DESC LIMIT 5")
  34. # result = cur.fetchall() # для получения результата запроса (будет список кортежей)
  35. # Для экономии памяти (не формируется весь список записей)
  36. for result in cur:
  37. print(result)
  38. # result_2 = cur.fetchone() # получить одну запись
  39. # result_3 = cur.fetchmany(3) # получить N записей
  40. # con.close()
  41. def main():
  42. # test_1()
  43. saper_db()
  44. if __name__ == '__main__':
  45. main()