Staging
v0.5.1
https://github.com/python/cpython
Raw File
Tip revision: 93b7677f9cc44afb3269bd81cbd359c6f5798581 authored by Ned Deily on 04 March 2020, 07:37:27 UTC
3.7.7rc1
Tip revision: 93b7677
mysumaggr.py
import sqlite3

class MySum:
    def __init__(self):
        self.count = 0

    def step(self, value):
        self.count += value

    def finalize(self):
        return self.count

con = sqlite3.connect(":memory:")
con.create_aggregate("mysum", 1, MySum)
cur = con.cursor()
cur.execute("create table test(i)")
cur.execute("insert into test(i) values (1)")
cur.execute("insert into test(i) values (2)")
cur.execute("select mysum(i) from test")
print(cur.fetchone()[0])

con.close()
back to top