Python ile ilişkisel veritabanlarını sorgulama

Python'da Veri Aktarmaya Giriş

Hugo Bowne-Anderson

Data Scientist at DataCamp

Temel SQL sorgusu

SELECT * FROM Table_Name
  • Tablodaki tüm satırların tüm sütunlarını döndürür
  • Örnek:
SELECT * FROM Orders
  • SQLAlchemy ve pandas kullanacağız
Python'da Veri Aktarmaya Giriş

SQL sorgulama iş akışı

  • Paketleri ve işlevleri içe aktarın
  • Veritabanı motorunu oluşturun
  • Motora bağlanın
  • Veritabanını sorgulayın
  • Sonuçları bir DataFrame’e kaydedin
  • Bağlantıyı kapatın
Python'da Veri Aktarmaya Giriş

İlk SQL sorgunuz

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()
Python'da Veri Aktarmaya Giriş

Sorgu sonuçlarını yazdırma

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
Python'da Veri Aktarmaya Giriş

DataFrame sütun adlarını ayarlama

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()
Python'da Veri Aktarmaya Giriş

Veri çerçevesi sütun adlarını ayarlama

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
Python'da Veri Aktarmaya Giriş

Bağlam yöneticisini kullanma

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()
Python'da Veri Aktarmaya Giriş

Hadi pratik yapalım!

Python'da Veri Aktarmaya Giriş

Preparing Video For Download...