當前位置: 首頁>>代碼示例>>Python>>正文


Python Connection.cursor方法代碼示例

本文整理匯總了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)
開發者ID:eugene-eeo,項目名稱:graphlite,代碼行數:60,代碼來源:graph.py

示例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()
開發者ID:Antiade,項目名稱:tribler,代碼行數:33,代碼來源:torrent_upgrade64.py

示例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()
開發者ID:Antiade,項目名稱:tribler,代碼行數:29,代碼來源:db_upgrader.py

示例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
開發者ID:lrem,項目名稱:ladders,代碼行數:9,代碼來源:ranking.py

示例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]
開發者ID:ArieClaassens,項目名稱:esri2open,代碼行數:30,代碼來源:prepare.py

示例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]
        )
開發者ID:wencakisa,項目名稱:Softuni-Python3,代碼行數:10,代碼來源:db_utils.py

示例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)]
        )
開發者ID:wencakisa,項目名稱:Softuni-Python3,代碼行數:10,代碼來源:db_utils.py

示例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
開發者ID:yaroot,項目名稱:scripts,代碼行數:11,代碼來源:fav.py

示例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,))
開發者ID:hnlaomie,項目名稱:python-tools,代碼行數:14,代碼來源:db_utils.py

示例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)
開發者ID:hnlaomie,項目名稱:python-tools,代碼行數:15,代碼來源:db_utils.py

示例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()
開發者ID:yaroot,項目名稱:scripts,代碼行數:16,代碼來源:fav.py

示例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)
開發者ID:mtgjson,項目名稱:mtgsqlive,代碼行數:16,代碼來源:json2sql.py

示例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)
開發者ID:hnlaomie,項目名稱:python-tools,代碼行數:17,代碼來源:db_utils.py

示例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)
開發者ID:hnlaomie,項目名稱:python-tools,代碼行數:19,代碼來源:db_utils.py

示例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)
開發者ID:hnlaomie,項目名稱:python-tools,代碼行數:20,代碼來源:db_utils.py


注:本文中的sqlite3.Connection.cursor方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。