python连接postgresql数据库

连接postgresql数据库
pip install psycopg2

## 导入psycopg2包
import psycopg2
## 连接到一个给定的数据库
conn = psycopg2.connect(database="postgres", user="postgres",
                        password="postgres", host="127.0.0.1", port="23333")
## 建立游标,用来执行数据库操作
cursor = conn.cursor()

## 执行SQL命令
cursor.execute("DROP TABLE test_conn")
cursor.execute("CREATE TABLE test_conn(id int, name text)")
cursor.execute("INSERT INTO test_conn values(1,'haha')")

## 提交SQL命令
conn.commit()

## 执行SQL SELECT命令
cursor.execute("select * from test_conn")

## 获取SELECT返回的元组
rows = cursor.fetchall()
for row in rows:
    print 'id = ',row[0], 'name = ', row[1], '\n'

## 关闭游标
cursor.close()

## 关闭数据库连接
conn.close()

参数化查询
#list参数化查询
#sql = "select * from pg_tables where schemaname=%s and tablename=%s"
#csor.execute(sql, ['internal_app_bsaata', 'event_ip_real'])
#dict参数化查询
sql = "select * from pg_tables where schemaname=%(db_name)s and tablename=%(tb_name)s"
csor.execute(sql, {'db_name':'internal_app_bsaata', 'tb_name':'event_ip_real'})

##多条数据处理
namedict = ({"first_name":"Joshua", "last_name":"Drake"},
            {"first_name":"Steven", "last_name":"Foo"},
            {"first_name":"David", "last_name":"Bar"})
cur = conn.cursor()
cur.executemany("""INSERT INTO bar(first_name,last_name) VALUES (%(first_name)s, %(last_name)s)""", namedict)

注意:sql执行失败后,需要回滚才能继续执行后面的sql

    try:## 执行SQL命令dbconn.cursor.execute(sql)## 提交SQL命令dbconn.conn.commit()except Exception as e:dbconn.conn.rollback()logging.exception(e)    # 方式2


-----------自己写的dbhelper.py

# coding:utf-8
import loggingimport psycopg2def dbconn(config):dbconn.conn = psycopg2.connect(database=config["database"], user=config["user"],password=config["password"], host=config["host"],port=config["port"])## 建立游标,用来执行数据库操作dbconn.cursor = dbconn.conn.cursor()def exec_sql(sql):#print sqltry:## 执行SQL命令dbconn.cursor.execute(sql)## 提交SQL命令dbconn.conn.commit()except Exception as e:dbconn.conn.rollback()logging.exception(e)    # 方式2def exec_sql_muti(sql,params):#print sqltry:## 执行SQL命令dbconn.cursor.executemany(sql,params)## 提交SQL命令dbconn.conn.commit()except Exception as e:dbconn.conn.rollback()logging.exception(e)    # 方式2def query(sql):print sqldbconn.cursor.execute(sql);return dbconn.cursordef dbclose():dbconn.cursor.close()dbconn.conn.close()

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/416998.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

前端学习(2352):view组件的使用

detail.vue <template><view><!-- <view class""><text>唱歌跳舞</text></view><view seletable><text>唱歌跳舞</text></view><view seletable space"ensp"><text>唱歌 …

Fatal error compiling: java.lang.ExceptionInInitializerError: com.sun.tools.javac.code.TypeTags

项目换用openjdk11后报错 Fatal error compiling: java.lang.ExceptionInInitializerError: com.sun.tools.javac.code.TypeTags 原因&#xff1a;lombok版本太低了&#xff0c;不支持java11 升级版本&#xff1a;到 1.18.6 <dependency> <groupId>org.projectl…

Spring集成JavaMail并利用线程池发送邮件

我们系统存在大量发送邮件的需求&#xff0c;项目使用的是Spring框架而JavaMail也能很好的跟Spring进行集成&#xff0c;由于发送邮件最好还是使用异步进行发送&#xff0c;所以这里就采用线程池JavaMail进行邮件发送&#xff0c;下面看具体代码实现&#xff1a; Step1、引入Ja…

计算机里创建本地磁盘分区,大神教你如何将本地硬盘进行分区!

如何将本地硬盘进行分区呢&#xff1f;不少小伙伴的电脑上只有一个磁盘C&#xff0c;这样子的话很容易造成磁盘空间不足&#xff0c;可要是进行分区一下的话&#xff0c;那么就不会有这个困扰咯&#xff0c;所以今天小编就来教教大家在不借助任何工具的情况下把本地硬盘进行分区…

consul通过web接口的kv存储操作

接口文档详见https://www.consul.io/api/kv.html 获取指定key的value Method Path Produces GET /kv/:key application/json curl http://10.129.63.40:9001/v1/kv/config/application/data key为config/application/data 返回值 [ { "LockIndex": 0, &qu…

前端学习(2353):button按钮组件的使用

detail.vue <template><view><!-- <view class""><text>唱歌跳舞</text></view><view seletable><text>唱歌跳舞</text></view><view seletable space"ensp"><text>唱歌 …

三维触控测试软件,10 条小技巧,告诉你 iPhone XS Max 的三维触控功能怎么用

苹果在 2018 年发布了 iPhone XS 系列&#xff0c;并且这两款设备都支持 3D Touch(三维触控)&#xff0c;如果您还不太了解这项功能的实用之处&#xff0c;不妨一起来看看&#xff1a;如何开启&#xff1f;前往 iPhone 【设置】-【通用】-【辅助功能】-【三维触控】&#xff0c…

1、math模块

常用math模块方法与常量 import math#math.ceil(n)返回大于等于n的整数 n1 3.141592654 s1 math.ceil(n1) print(s1) # 4#math.copysign(x,y)返回x的绝对值与y的符号 n2 -3.14 s2 math.copysign(n2,1) s3 math.copysign(n2,-1) print(s2,s3) #3.14 -3.14#math.fabs(x) 返回…

Spring Cloud 采用Consul做配置中心

-----------------pom.xml依赖&#xff0c;主要是spring-cloud-starter-consul-config <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId> </dependency> <dependency><…

前端学习(2354):image组件的基本使用

pages.json <template><view><!-- <view class""><text>唱歌跳舞</text></view><view seletable><text>唱歌跳舞</text></view><view seletable space"ensp"><text>唱歌 …

vasp服务器中断,求助VASP能带计算的中断原因

我也遇到类似情况&#xff0c;发现服务器内存没有用到多少&#xff1f;是不是并行环境有问题&#xff1f;谢谢&#xff01;DA part: xc-table for Pade appr. of PerdewPOSCAR, INCAR and KPOINTS ok, starting setupWARNING: small aliasing (wrap around) errors must be exp…

Java多线程(一)

线程问题&#xff0c;或称并发 创建线程一般有一下方法 继承Thread类&#xff0c;重写run方法 1 public class TestThread extends Thread{ 2 public void run() { 3 System.out.println("Hello World"); 4 } 5 public static void m…

git 大文件报错Out of memory, malloc failed、 The remote end hung up unexpectedly

git clone出现 "fatal: The remote end hung up unexpectedly" 设置 git config --global http.postBuffer 104857600000 后git clone报错 fatal: Out of memory, malloc failed (tried to allocate 1778384896 bytes) 又把postBuffer改了回去 git config --glo…

前端学习(2355):uni里面的样式学习

style.vue <template><view><view class"box">我是歌谣</view></view> </template><script>export default {data() {return {}},methods: {}} </script><style> .box{width: 375rpx;height: 375rpx;backgrou…

目前市场上的电脑一体机从计算机种类,一体机电脑与普通电脑的区别

现在&#xff0c;市场上开始流行一体机电脑了&#xff0c;很多网友可能会对一体机电脑感兴趣。下面&#xff0c;本文针对市场上的一体机电脑优劣作一个简要说明。一、一体机电脑的好处由于一体机电脑&#xff0c;所有的设备都封装在同一个容器内&#xff0c;就连显示屏都和电脑…

C#之调用存储过程

C#调用存储过程 以下内容可能有错漏之处&#xff0c;请大家多多指教。 C#后台代码如下&#xff1a; //调用存储过程的方法public static void Startupworkflow(string firstnodename, string secondnodename, string firstact) { SqlConnection conn new Sq…

css3修改透明png颜色

实现思路&#xff1a; 图片作为背景&#xff0c;drop-shadow阴影形成新的元素&#xff0c;再用left把整体偏移回去&#xff0c;最后用overflow:hidden把原图片隐藏 注&#xff1a;当放在其他绝对定位的元素上面时注意z-index的处理。 .iconXXX{overflow:hidden;display: inl…

计算机速录比赛主题,弘扬汉字,全国输入法表演赛电脑输入法比赛组速录表演组的报名...

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼“弘扬汉字&#xff0c;全国输入法表演赛”组委会、评委、电脑输入法比赛组、速录表演组的报名现在已陆续报名&#xff0c;没有报名的赶快报名&#xff0c;有方案展示的也可以参加&#xff0c;没有填写详细信息的请及时填写&#x…

前端学习(2357):uni的基本数据绑定

<template><view><view>{{msg}}</view><view>{{你好世界}}</view></view> </template><script>export default {data() {return {msg:hello}},methods: {}} </script><style></style>运行结果