Relationele databases bevragen in Python

Introductie tot data importeren in Python

Hugo Bowne-Anderson

Data Scientist at DataCamp

Basis SQL-query

SELECT * FROM Table_Name
  • Geeft alle kolommen van alle rijen van de tabel
  • Voorbeeld:
SELECT * FROM Orders
  • We gebruiken SQLAlchemy en pandas
Introductie tot data importeren in Python

Workflow van SQL-querying

  • Importeer pakketten en functies
  • Maak de database-engine
  • Verbind met de engine
  • Query de database
  • Sla resultaten op in een DataFrame
  • Sluit de verbinding
Introductie tot data importeren in Python

Je eerste SQL-query

from sqlalchemy import create_engine
import pandas as pd

engine = create_engine('sqlite:///Northwind.sqlite')
con = engine.connect()
rs = con.execute("SELECT * FROM Orders")
df = pd.DataFrame(rs.fetchall())
con.close()
Introductie tot data importeren in Python

Je queryresultaten printen

print(df.head())
       0      1   2                      3                      4 
0  10248  VINET   5   7/4/1996 12:00:00 AM   8/1/1996 12:00:00 AM   
1  10251  VICTE   3   7/8/1996 12:00:00 AM   8/5/1996 12:00:00 AM   
2  10254  CHOPS   5  7/11/1996 12:00:00 AM   8/8/1996 12:00:00 AM   
3  10256  WELLI   3  7/15/1996 12:00:00 AM  8/12/1996 12:00:00 AM   
4  10258  ERNSH   1  7/17/1996 12:00:00 AM  8/14/1996 12:00:00 AM
Introductie tot data importeren in Python

Stel de kolomnamen van het DataFrame in

from sqlalchemy import create_engine
import pandas as pd
engine = create_engine('sqlite:///Northwind.sqlite')
con = engine.connect()
rs = con.execute("SELECT * FROM Orders")
df = pd.DataFrame(rs.fetchall())
df.columns = rs.keys()
con.close()
Introductie tot data importeren in Python

Stel de kolomnamen van de data frame in

print(df.head())
   OrderID CustomerID  EmployeeID              OrderDate  
0    10248      VINET           5   7/4/1996 12:00:00 AM   
1    10251      VICTE           3   7/8/1996 12:00:00 AM   
2    10254      CHOPS           5  7/11/1996 12:00:00 AM   
3    10256      WELLI           3  7/15/1996 12:00:00 AM   
4    10258      ERNSH           1  7/17/1996 12:00:00 AM
Introductie tot data importeren in Python

De contextmanager gebruiken

from sqlalchemy import create_engine
import pandas as pd
engine = create_engine('sqlite:///Northwind.sqlite')
with engine.connect() as con:
    rs = con.execute("SELECT OrderID, OrderDate, ShipName FROM Orders")
    df = pd.DataFrame(rs.fetchmany(size=5))
    df.columns = rs.keys()
Introductie tot data importeren in Python

Laten we oefenen!

Introductie tot data importeren in Python

Preparing Video For Download...