校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > python sqlite3 判斷cursor的結果是否為空的案例

python sqlite3 判斷cursor的結果是否為空的案例

熱門標簽:地圖標注推廣單頁 長春人工智能電銷機器人官網 西藏快速地圖標注地點 女王谷地圖標注 n400電話申請多少錢 ai地圖標注 百應ai電銷機器人鄭州 廈門crm外呼系統如何 如何在地圖標注文字

len(list(cursor))若是0則為空

舉例:

import sqlite3
 
# CREATE
 db = sqlite3.connect("E:/Pycharm/workspace/django_test/user.db")
 db.execute("create table user(info primary key,flag,result )")
 db.execute("insert into user(info,flag,result) values('RikkaTakanashi','0','DarkFlameMaster')")
 db.commit()
 db.close()
db = sqlite3.connect("E:/Pycharm/workspace/django_test/user.db")
c=db.cursor()
cursor=c.execute("select info,flag,result from user where info='123'")
print(len(list(cursor)))

結果為0

db = sqlite3.connect("E:/Pycharm/workspace/django_test/user.db")
c=db.cursor()
cursor=c.execute("select info,flag,result from user where info='RikkaTakanashi'")
print(len(list(cursor)))

結果為1

補充:python中的SQLite游標(cursor)

我們知道關系數據庫管理系統實質是面向集合的,在Sqlite中并沒有一種描述表中單一記錄的表達形式,除非使用where 子句來限制只有一條記錄被選中。因此我們必須借助于游標來進行面向單條記錄的數據處理。由此可見,游標允許應用程序對查詢語句select 返回的行結果集中每一行進行相同或不同的操作,而不是一次對整個結果集進行同一種操作;它還提供對基于游標位置而對表中數據進行刪除或更新的能力;正是游標把作為面向集合的數據庫管理系統和面向行的程序設計兩者聯系起來,使兩個數據處理方式能夠進行溝通。

游標提供了一種對從表中檢索出的數據進行操作的靈活手段,就本質而言,游標實際上是一種能從包括多條數據記錄的結果集中每次提取一條記錄的機制。游標總是與一條SQL 選擇語句相關聯。因為游標由結果集(可以是零條、一條或由相關的選擇語句檢索出的多條記錄)和結果集中指向特定記錄的游標位置組成。當決定對結果集進行處理時,必須聲明一個指向該結果集的游標。如果曾經用 C 語言寫過對文件進行處理的程序,那么游標就像您打開文件所得到的文件句柄一樣,只要文件打開成功, 該文件句柄就可代表該文件。對于游標而言,其道理是相同的。可見游標能夠實現按與傳統程序讀取平面文件類似的方式處理來自基礎表的結果集,從而把表中數據以平面文件的形式呈現給程序。

使用Python的SQLite時,只要搞清楚Connection和Cursor對象,打開后一定記得關閉,就可以放心地使用。

使用Cursor對象執行insert,update,delete語句時,執行結果由rowcount返回影響的行數,就可以拿到執行結果。

使用Cursor對象執行select語句時,通過featchall()返回select的全部數據結果集。結果集是一個list,每個元素都是一個tuple,對應一行記錄,按建表的字段順序排列。fetchone()返回一條結果,是一個tuple,每個元素是一個字段值。

需要注意的是,SQLite游標是有狀態的,只能遍歷結果集一次,不能在結果集中返回移動,遍歷結束返回空值。featchall()一次性返回全部結果,fetchone()依順序每次返回一條結果,而且對fetchone()執行len()操作以獲得所取得記錄的條數后,相當于完成對結果集的一次遍歷,結果集將被清空。因此,取得結果集后,如需對結果集進行進一步操作,可將結果集保存到變量中。

while cn.fetchone():
 print(cn.fetchone())
for line in cn.featchall():
 print(line)

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。

您可能感興趣的文章:
  • Python標準庫之數據庫 sqlite3
  • python數據庫如何連接SQLite詳解
  • python 操作sqlite數據庫的方法
  • Python 操作SQLite數據庫的示例
  • python鏈接sqlite數據庫的詳細代碼實例

標簽:綿陽 廊坊 興安盟 黔東 亳州 渭南 拉薩 內江

巨人網絡通訊聲明:本文標題《python sqlite3 判斷cursor的結果是否為空的案例》,本文關鍵詞  python,sqlite3,判斷,cursor,的,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《python sqlite3 判斷cursor的結果是否為空的案例》相關的同類信息!
  • 本頁收集關于python sqlite3 判斷cursor的結果是否為空的案例的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 安化县| 远安县| 澄城县| 肃宁县| 万全县| 青浦区| 漠河县| 延长县| 灵武市| 西乌珠穆沁旗| 菏泽市| 昂仁县| 辉南县| 普兰县| 普定县| 昭觉县| 黄冈市| 巫山县| 肇源县| 枞阳县| 鞍山市| 克拉玛依市| 广平县| 额敏县| 长泰县| 清水河县| 临海市| 阿瓦提县| 元谋县| 密山市| 浦江县| 南京市| 深水埗区| 济南市| 什邡市| 澄迈县| 邛崃市| 遵化市| 元阳县| 宕昌县| 青阳县|