Menghitung nilai dalam kueri

Pengantar Basis Data di Python

Jason Myers

Co-Author of Essential SQLAlchemy and Software Engineer

Operator matematika

  • penjumlahan +
  • pengurangan -
  • perkalian *
  • pembagian /
  • modulus %
  • Bekerja berbeda pada tiap tipe data
Pengantar Basis Data di Python

Menghitung selisih

stmt = select([census.columns.age,           
        (census.columns.pop2008 -
        census.columns.pop2000).label('pop_change')
    ])

stmt = stmt.group_by(census.columns.age) stmt = stmt.order_by(desc('pop_change'))
stmt = stmt.limit(5)
results = connection.execute(stmt).fetchall() print(results)
[(61, 52672), (85, 51901), (54, 50808), (58, 45575),
(60, 44915)]
Pengantar Basis Data di Python

Pernyataan CASE

  • Untuk memperlakukan data berbeda berdasar kondisi
  • Menerima daftar kondisi dan kolom yang dikembalikan jika cocok
  • Diakhiri dengan klausa else untuk menangani record yang tidak cocok kondisi sebelumnya
Pengantar Basis Data di Python

Contoh CASE

from sqlalchemy import case

stmt = select([ func.sum( case([ (census.columns.state == 'New York', census.columns.pop2008) ], else_=0))])
results = connection.execute(stmt).fetchall() print(results)
[(19465159,)]
Pengantar Basis Data di Python

Pernyataan CAST

  • Mengonversi data ke tipe lain
  • Berguna untuk mengonversi...
    • integer ke float untuk pembagian
    • string ke tanggal dan waktu
  • Menerima kolom atau ekspresi dan Type target
Pengantar Basis Data di Python

Contoh persentase

from sqlalchemy import case, cast, Float

stmt = select([ (func.sum( case([ (census.columns.state == 'New York', census.columns.pop2008) ], else_=0)) / cast(func.sum(census.columns.pop2008), Float) * 100).label('ny_percent')])
results = connection.execute(stmt).fetchall() print(results)
[(Decimal('6.4267619765'),)]
Pengantar Basis Data di Python

Ayo berlatih!

Pengantar Basis Data di Python

Preparing Video For Download...