本文整理匯總了Python中sqlite3.Connection.cursor方法的典型用法代碼示例。如果您正苦於以下問題:Python Connection.cursor方法的具體用法?Python Connection.cursor怎麽用?Python Connection.cursor使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類sqlite3.Connection
的用法示例。
在下文中一共展示了Connection.cursor方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: Graph
# 需要導入模塊: from sqlite3 import Connection [as 別名]
# 或者: from sqlite3.Connection import cursor [as 別名]
class Graph(object):
"""
Initializes a new Graph object.
:param uri: The URI of the SQLite db.
:param graphs: Graphs to create.
"""
def __init__(self, uri, graphs=()):
self.uri = uri
self.db = Connection(database=uri)
self.setup_sql(graphs)
def setup_sql(self, graphs):
"""
Sets up the SQL tables for the graph object,
and creates indexes as well.
:param graphs: The graphs to create.
"""
with closing(self.db.cursor()) as cursor:
for table in graphs:
cursor.execute(SQL.CREATE_TABLE % (table))
for index in SQL.INDEXES:
cursor.execute(index % (table))
self.db.commit()
def close(self):
"""
Close the SQLite connection.
"""
self.db.close()
__del__ = close
def __contains__(self, edge):
"""
Checks if an edge exists within the database
with the given source and destination nodes.
:param edge: The edge to query.
"""
with closing(self.db.cursor()) as cursor:
cursor.execute(*SQL.select_one(edge.src, edge.rel, edge.dst))
return bool(cursor.fetchall())
def find(self, edge_query):
"""
Returns a Query object that acts on the graph.
"""
return Query(self.db)(edge_query)
def transaction(self):
"""
Returns a Transaction object. All modifying
operations, i.e. ``store``, ``delete`` must
then be performed on the transaction object.
"""
return Transaction(self.db)
示例2: _update_dispersy
# 需要導入模塊: from sqlite3 import Connection [as 別名]
# 或者: from sqlite3.Connection import cursor [as 別名]
def _update_dispersy(self):
"""
Cleans up all SearchCommunity and MetadataCommunity stuff in dispersy database.
"""
db_path = os.path.join(self.session.get_state_dir(), u"sqlite", u"dispersy.db")
if not os.path.isfile(db_path):
return
communities_to_delete = (u"SearchCommunity", u"MetadataCommunity")
connection = Connection(db_path)
cursor = connection.cursor()
data_updated = False
for community in communities_to_delete:
try:
result = list(cursor.execute(u"SELECT id FROM community WHERE classification == ?", (community,)))
for community_id, in result:
self._logger.info(u"deleting all data for community %s...", community_id)
cursor.execute(u"DELETE FROM community WHERE id == ?", (community_id,))
cursor.execute(u"DELETE FROM meta_message WHERE community == ?", (community_id,))
cursor.execute(u"DELETE FROM sync WHERE community == ?", (community_id,))
data_updated = True
except StopIteration:
continue
if data_updated:
connection.commit()
cursor.close()
connection.close()
示例3: _purge_old_search_metadata_communities
# 需要導入模塊: from sqlite3 import Connection [as 別名]
# 或者: from sqlite3.Connection import cursor [as 別名]
def _purge_old_search_metadata_communities(self):
"""
Cleans up all SearchCommunity and MetadataCommunity stuff in dispersy database.
"""
db_path = os.path.join(self.session.get_state_dir(), u"sqlite", u"dispersy.db")
if not os.path.isfile(db_path):
return
communities_to_delete = (u"SearchCommunity", u"MetadataCommunity", u"TunnelCommunity")
connection = Connection(db_path)
cursor = connection.cursor()
for community in communities_to_delete:
try:
result = list(cursor.execute(u"SELECT id FROM community WHERE classification == ?;", (community,)))
for community_id, in result:
cursor.execute(u"DELETE FROM community WHERE id == ?;", (community_id,))
cursor.execute(u"DELETE FROM meta_message WHERE community == ?;", (community_id,))
cursor.execute(u"DELETE FROM sync WHERE community == ?;", (community_id,))
except StopIteration:
continue
cursor.close()
connection.commit()
connection.close()
示例4: __init__
# 需要導入模塊: from sqlite3 import Connection [as 別名]
# 或者: from sqlite3.Connection import cursor [as 別名]
def __init__(self, ladder: str, dbh: sqlite3.Connection) -> None:
self.ladder = ladder
self.dbh = dbh
self.cursor = dbh.cursor()
self.players: Dict[str, Player] = {}
self.tsh: trueskill.TrueSkill = None
self.last_ranking = 0
示例5: prepareSqlite
# 需要導入模塊: from sqlite3 import Connection [as 別名]
# 或者: from sqlite3.Connection import cursor [as 別名]
def prepareSqlite(out,featureClass,fileType,includeGeometry):
[shp,shpType]=getShp(featureClass)
if shpType == "point":
gType = 1
elif shpType == "multipoint":
gType = 4
elif shpType == "polyline":
gType = 5
elif shpType == "polygon":
gType = 6
fields=listFields(featureClass)
fieldNames = []
fieldNames.append("OGC_FID INTEGER PRIMARY KEY")
if includeGeometry:
fieldNames.append("GEOMETRY blob")
for field in fields:
if (fields[field] != u'OID') and field.lower() !=shp.lower():
fieldNames.append(parseFieldType(field,fields[field]))
conn=Connection(out)
c=conn.cursor()
name = splitext(split(out)[1])[0]
c.execute("""CREATE TABLE geometry_columns ( f_table_name VARCHAR, f_geometry_column VARCHAR, geometry_type INTEGER, coord_dimension INTEGER, srid INTEGER, geometry_format VARCHAR )""")
c.execute("""insert into geometry_columns( f_table_name, f_geometry_column, geometry_type, coord_dimension, srid, geometry_format) values(?,?,?,?,?,?)""",(name,"GEOMETRY",gType,2,4326,"WKB"))
c.execute("""CREATE TABLE spatial_ref_sys ( srid INTEGER UNIQUE, auth_name TEXT, auth_srid TEXT, srtext TEXT)""")
c.execute("insert into spatial_ref_sys(srid ,auth_name ,auth_srid ,srtext) values(?,?,?,?)",(4326, u'EPSG', 4326, u'GEOGCS["WGS 84",DATUM["WGS_1984",SPHEROID["WGS 84",6378137,298.257223563,AUTHORITY["EPSG","7030"]],AUTHORITY["EPSG","6326"]],PRIMEM["Greenwich",0,AUTHORITY["EPSG","8901"]],UNIT["degree",0.0174532925199433,AUTHORITY["EPSG","9122"]],AUTHORITY["EPSG","4326"]]'))
c.execute("create table {0}({1})".format(name,", ".join(fieldNames)))
return [name,c,conn]
示例6: import_catalog_into_db
# 需要導入模塊: from sqlite3 import Connection [as 別名]
# 或者: from sqlite3.Connection import cursor [as 別名]
def import_catalog_into_db(catalog: Dict[str, CatalogEntry], connection: sqlite3.Connection):
cursor = connection.cursor()
for catalog_entry in catalog.values():
cursor.execute(
'insert into catalog (item_key, category_name) values (?, ?);',
[catalog_entry.item_key, catalog_entry.category_name]
)
示例7: import_sales_into_db
# 需要導入模塊: from sqlite3 import Connection [as 別名]
# 或者: from sqlite3.Connection import cursor [as 別名]
def import_sales_into_db(sales, connection: sqlite3.Connection):
cursor = connection.cursor()
for sale in sales:
cursor.execute(
'insert into sales (item_key, country, city_name, sale_timestamp, price) values (?, ?, ?, ?, ?);',
[sale.item_key, sale.country, sale.city_name, sale.timestamp.isoformat(), str(sale.price)]
)
示例8: load_max_id
# 需要導入模塊: from sqlite3 import Connection [as 別名]
# 或者: from sqlite3.Connection import cursor [as 別名]
def load_max_id(db: sqlite3.Connection):
cur = db.cursor()
cur.execute('select min(id) from fav_tweets')
r = cur.fetchone()
db.rollback()
cur.close()
if r:
return r[0]
pass
示例9: refresh_disable_proxies
# 需要導入模塊: from sqlite3 import Connection [as 別名]
# 或者: from sqlite3.Connection import cursor [as 別名]
def refresh_disable_proxies(conn: Connection):
"""
刷新失效的代理,失效一天以上就可刪除
:param conn: 數據連接
:return:
"""
delete_sql = '''
DELETE FROM disable_proxies
WHERE CAST(strftime('%s', datetime('now', 'localtime')) - strftime('%s', insert_date) as INTEGER) > ?
'''
cur = conn.cursor()
cur.execute(delete_sql, (day_of_seconds,))
示例10: insert_disable_proxy
# 需要導入模塊: from sqlite3 import Connection [as 別名]
# 或者: from sqlite3.Connection import cursor [as 別名]
def insert_disable_proxy(conn: Connection, proxy: ()):
"""
寫入失效的代理
:param conn: 數據連接
:param proxy: (代理)
:return:
"""
insert_sql = '''
INSERT OR IGNORE INTO disable_proxies (proxy, insert_date)
VALUES (?, datetime('now', 'localtime'))
'''
cur = conn.cursor()
cur.execute(insert_sql, proxy)
示例11: insert
# 需要導入模塊: from sqlite3 import Connection [as 別名]
# 或者: from sqlite3.Connection import cursor [as 別名]
def insert(db: sqlite3.Connection, t):
id = int(t['id_str'])
created_at = int(timestamp_from_id(id))
cur = db.cursor()
cur.execute(
"""
INSERT INTO fav_tweets (`id`, `tweet`, `created_at`)
VALUES (?, ?, ?)
ON CONFLICT (`id`) DO NOTHING
""",
(id, json.dumps(t), created_at)
)
db.commit()
cur.close()
示例12: sql_dict_insert
# 需要導入模塊: from sqlite3 import Connection [as 別名]
# 或者: from sqlite3.Connection import cursor [as 別名]
def sql_dict_insert(
data: Dict[str, Any], table: str, sql_connection: sqlite3.Connection
) -> None:
"""
Insert a dictionary into a sqlite table
:param data: Dict to insert
:param table: Table to insert to
:param sql_connection: SQL connection
"""
cursor = sql_connection.cursor()
columns = ", ".join(data.keys())
placeholders = ":" + ", :".join(data.keys())
query = "INSERT INTO " + table + " (%s) VALUES (%s)" % (columns, placeholders)
cursor.execute(query, data)
示例13: update_proxy_error
# 需要導入模塊: from sqlite3 import Connection [as 別名]
# 或者: from sqlite3.Connection import cursor [as 別名]
def update_proxy_error(conn: Connection, proxy_list: []) -> []:
"""
批量更新代理信息表中代理錯誤次數
:param conn: 數據連接
:proxy_list: 代理列表[(代理1), (代理1), ... , (代理n)]
:return:
"""
update_sql = '''
UPDATE OR IGNORE proxy_list
SET error_count = error_count + 1
WHERE proxy = ?
'''
cur = conn.cursor()
cur.executemany(update_sql, proxy_list)
示例14: update_tac_status
# 需要導入模塊: from sqlite3 import Connection [as 別名]
# 或者: from sqlite3.Connection import cursor [as 別名]
def update_tac_status(conn: Connection, tac_data: ()):
"""
更新tac的狀態
:param conn: 數據連接
:param tac_data: (狀態,tac)
狀態:(2:不存在,3:查詢錯)
:return:
"""
update_sql = '''
UPDATE OR IGNORE tac_info
SET status = ? ,
query_count = query_count + 1 ,
update_date = datetime('now', 'localtime')
WHERE tac_id = ?
'''
cur = conn.cursor()
cur.execute(update_sql, tac_data)
示例15: reload_activate_proxies
# 需要導入模塊: from sqlite3 import Connection [as 別名]
# 或者: from sqlite3.Connection import cursor [as 別名]
def reload_activate_proxies(conn: Connection, data_list: []):
"""
載入活躍代理,載入前先清空數據
:param conn: 數據連接
:param data_list: 代理列表,格式為:[(proxy1, response_time1, test_time1, test_xp1),...,(proxyn, response_timen, test_timen, test_xpn)]
:return:
"""
delete_sql = '''
DELETE FROM activate_proxies
'''
insert_sql = '''
INSERT INTO activate_proxies (proxy, response_time, test_time, test_xp, insert_date)
VALUES (?, ?, ?, ?, datetime('now', 'localtime'))
'''
cur = conn.cursor()
cur.execute(delete_sql)
cur.executemany(insert_sql, data_list)