python3 sqlite3限制条件查询的操作


Posted in Python onApril 07, 2021

请注意10,11,24行的代码,是本条博客的精华,逻辑并不难,就是有些小语法问题比较纠结,记录一下。

import json 
import sqlite3
import re
import argparse
def Get(db_file):
  
    conn = sqlite3.connect(db_file)
    cur = conn.cursor()
    print("5555555")
    value1=(60)# this is must be ()
    cur.execute("select * from exception where AGV_ID=(%s)" %(value1))
    #cursor.execute("insert into exception values('%s', '%s','%s' ) " %(start_time ,ID ,infomation))
 
    result= cur.fetchall()
    print("result:",result)
    for i in result:
       print(i)  
    print("******************************888")
  
def get_agv_id(db_file):
  try:
    conn = sqlite3.connect(db_file)
    cur = conn.cursor()
    cur.execute("select * from exception where AGV_ID=51")
    #print( cur.fetchall())
    result= cur.fetchall()
    for i in result:
       print(i)
  except sqlite3.Error,e:
    print(e)
    
if __name__ == '__main__': 
  parser = argparse.ArgumentParser(description='check the information of db')
  #parser.add_argument('-h', '--help', help='Statistics for abnormal information')
  parser.add_argument('-n', '--name', help=' the db of name ')
  args = vars(parser.parse_args())
  db_name = args['name']
  print("db_name:",db_name)
  conn = sqlite3.connect('db_name')
  cursor = conn.cursor()
  Get('fitkits.db')
  get_agv_id('fitkits.db')  
  
  conn.commit()
  conn.close() 
  print('DONE!')
  print("666")

补充:python + sqlite3 基本操作

连接数据库

import sqlite3 
# 连接数据库(如果不存在则创建)
conn = sqlite3.connect('test.db')
print("Opened database successfully")
 
# 创建游标
cursor = conn.cursor() 
...
 
# 关闭游标
cursor.close()
# 提交事物
conn.commit()
# 关闭连接
conn.close()

创建表

...
# 创建游标
cursor = conn.cursor()
 
# 创建表
sql = 'CREATE TABLE Student(id integer PRIMARY KEY autoincrement, Name varchar(30), Age integer)'
cursor.execute(sql)
 
# 提交事物
conn.commit()
...

插入数据

...
# 创建游标
cursor = conn.cursor()
 
# 插入数据
sql = "INSERT INTO Student(Name, Age) VALUES(\'love\', 22)"
cursor.execute(sql)
 
# 插入数据 2
data = ('love2', 2221) # or ['love2', 2221]
sql = "INSERT INTO Student(Name, Age) VALUES(?, ?)"
cursor.execute(sql, data)
 
# 提交事物
conn.commit()
...

查询数据

...
# 创建游标
cursor = conn.cursor()
 
# 查询数据
sql = "select * from Student"
values = cursor.execute(sql)
for i in values:
 print(i)
 
# 查询数据 2
sql = "select * from Student where id=?"
values = cursor.execute(sql, (1,))
for i in values:
 print('id:', i[0])
 print('name:', i[1])
 print('age:', i[2])
 
# 提交事物
conn.commit()
...

其他操作

自增字段起始位置

# 设置起始值为1
update sqlite_sequence SET seq = 0 where name = '表名';
# 设置全部表起始值为默认值
delete from sqlite_sequence where name='TableName'; --注意表名区分大小写

以上为个人经验,希望能给大家一个参考,也希望大家多多支持三水点靠木。如有错误或未考虑完全的地方,望不吝赐教。

Python 相关文章推荐
python中zip()方法应用实例分析
Apr 16 Python
Python中线程的MQ消息队列实现以及消息队列的优点解析
Jun 29 Python
浅谈python 里面的单下划线与双下划线的区别
Dec 01 Python
Python设计模式之命令模式简单示例
Jan 10 Python
python try except 捕获所有异常的实例
Oct 18 Python
OpenCV+Python识别车牌和字符分割的实现
Jan 31 Python
5款Python程序员高频使用开发工具推荐
Apr 10 Python
Python机器学习算法库scikit-learn学习之决策树实现方法详解
Jul 04 Python
Django打印出在数据库中执行的语句问题
Jul 25 Python
对Tensorflow中Device实例的生成和管理详解
Feb 04 Python
python通过matplotlib生成复合饼图
Feb 06 Python
Python连接mysql方法及常用参数
Sep 01 Python
python实现高效的遗传算法
解决hive中导入text文件遇到的坑
Apr 07 #Python
python - asyncio异步编程
Apr 06 #Python
python - timeit 时间模块
Apr 06 #Python
python制作图形界面的2048游戏, 基于tkinter
python第三方网页解析器 lxml 扩展库与 xpath 的使用方法
Apr 06 #Python
python删除csv文件的行列
Apr 06 #Python
You might like
Django中的cookie与session操作实例代码
2017/08/17 PHP
TP(thinkPHP)框架多层控制器和多级控制器的使用示例
2018/06/13 PHP
PHP大文件分割分片上传实现代码
2020/12/09 PHP
javascript Select标记中options操作方法集合
2008/10/22 Javascript
jQuery.ajax 用户登录验证代码
2010/10/29 Javascript
三种取消选中单选框radio的方法
2014/09/09 Javascript
使用js获取地址栏参数的方法推荐(超级简单)
2016/06/14 Javascript
js实现简单的计算器功能
2017/01/16 Javascript
JS控件bootstrap datepicker使用方法详解
2017/03/25 Javascript
运用jQuery写的验证表单(实例讲解)
2017/07/06 jQuery
[原创]jquery判断元素内容是否为空的方法
2018/05/04 jQuery
webpack 样式加载的实现原理
2018/06/12 Javascript
vue.js实现插入数值与表达式的方法分析
2018/07/06 Javascript
解决vue无法设置滚动位置的问题
2018/10/07 Javascript
解决layer.prompt无效的问题
2019/09/24 Javascript
swiper实现导航滚动效果
2020/12/13 Javascript
vue3.0中友好使用antdv示例详解
2021/01/05 Vue.js
[02:45]DOTA2英雄基础教程 伐木机
2013/12/23 DOTA
[01:07:13]TNC vs Pain 2018国际邀请赛小组赛BO2 第一场 8.17
2018/08/20 DOTA
Python下的常用下载安装工具pip的安装方法
2015/11/13 Python
python爬虫使用cookie登录详解
2017/12/27 Python
python如何定义带参数的装饰器
2018/03/20 Python
Ubuntu16.04安装python3.6.5步骤详解
2020/01/10 Python
3D动画《斗罗大陆》上线当日播放过亿
2021/03/16 国漫
CSS3文本换行word-wrap解决英文文本超过固定宽度不换行
2013/10/10 HTML / CSS
html5使用window.postMessage进行跨域实现数据交互的一次实战
2021/02/24 HTML / CSS
Cotton On美国网站:澳洲时装连锁品牌
2016/10/25 全球购物
介绍一下grep命令的使用
2015/06/12 面试题
蛋糕店创业计划书
2014/05/06 职场文书
工商管理专业自荐信
2014/06/03 职场文书
教师自查自纠材料
2014/10/14 职场文书
会议主持人开场白台词
2015/05/28 职场文书
请客吃饭开场白
2015/06/01 职场文书
胡桃夹子观后感
2015/06/11 职场文书
适合后台管理系统开发的12个前端框架(小结)
2021/06/29 Javascript
js中Object.create实例用法详解
2021/10/05 Javascript