国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

python 插入Null值數據到Postgresql的操作

瀏覽:84日期:2022-06-26 09:35:47

數據庫中最好插入Null值。

在python中,暫時沒找到通過sql語句的方式插入Null值。

推薦使用輪子的方法

def insert_sample_data(self, values): # added self since you are referencing it below with self.con.cursor() as cur: sql = 'insert into sampletable values (%s, %s, %s)' # Use %s for parameters cur.executemany(sql, values) # Pass the list of tuples directly self.con.commit() list1 = [(1100, ’abc’, ’{'1209': 'Y', '1210': 'Y'}’), (1100, ’abc’, None)]self.insert_sample_data(list1) # pass the list directly

補充:python連接數據庫插入數據庫數據所碰到的坑

Python中插入數據時執行后,沒有報任何錯誤,但數據庫中并沒有出現新添加的數據

原因:

缺少提交操作。

解決方案:

Python操作數據庫時,如果對數據表進行修改/刪除/添加等控制操作,系統會將操作保存在內存,只有執行commit(),才會將操作提交到數據庫。

但是總有你想不到的坑代碼如下:

import pymysql class Connection: def __init__(self): self.host = ’localhost’ self.user = ’nameit’ self.password = ’YES’ self.port = 3306 self.db = ’Xomai’ def connection(self): db = pymysql.connect(host=self.host, user=self.user, password=self.password, port=self.port, db=self.db) cur = db.cursor() return db, cur def create_table(self, cur): sql = '''CREATE TABLE `activity_feedback` ( `id` bigint(20) NOT NULL AUTO_INCREMENT, `inst_id` bigint(20) DEFAULT NULL COMMENT ’ID’, `broadcast_id` bigint(20) DEFAULT NULL COMMENT ’你好’, `student_id` bigint(20) DEFAULT NULL COMMENT ’學生ID’, `content` varchar(1024) DEFAULT NULL COMMENT ’學員內容’, `comment` varchar(255) DEFAULT NULL COMMENT ’注釋’, `gmt_create` datetime DEFAULT NULL, `gmt_modify` datetime DEFAULT NULL, PRIMARY KEY (`id`), KEY `activity_feedback_student_id_index` (`student_id`) ) ENGINE = InnoDB AUTO_INCREMENT = 1050 DEFAULT CHARSET = utf8mb4 COMMENT = ’學員表’''' cur.execute(sql) def insert(self, id, inst_id, broadcast_id, student_id, content, comment, gmt_create, gmt_modify): sql = '''INSERT INTO `activity_feedback` ( `id`, `inst_id`, `broadcast_id`, `student_id`, `content`, `comment`, `gmt_create`, `gmt_modify`) VALUES (’{}’,’{}’,’{}’,’{}’,’{}’,’{}’,’{}’,’{}’)'''.format(id, inst_id, broadcast_id, student_id, content, comment, gmt_create, gmt_modify) try: self.connection()[1].execute(sql) self.connection()[0].commit() except: self.connection()[0].rollback()if __name__ == ’__main__’: conn = Connection() conn.insert(123, 123, 324, 3451, ’ajdf’, ’sdfs’, ’2013-2-5’, ’2014-3-4’)

咋一看好像也有commit呀,怎么一直在數據庫沒有,再仔細看看

try: self.connection()[1].execute(sql) self.connection()[0].commit() except: self.connection()[0].rollback()

connection()調用方法方法返回的對象是同一個嗎?

并不是,心累,搞了半天,只怪自己還太嫩。

正確寫法:

try: cons = self.connection() cons[1].execute(sql) cons[0].commit() cons[0].close() except: cons[0].rollback()

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

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 欧美一级v片 | 男女福利社 | 亚洲国产精品久久综合 | 日本加勒比网站 | 男女视频在线观看免费高清观看 | 久久青草免费免费91线频观看 | 欧美视频免费一区二区三区 | 亚洲韩国欧美一区二区三区 | 国产韩国精品一区二区三区久久 | 亚欧人成精品免费观看 | 亚洲美女视频一区二区三区 | 亚洲视频在线观看免费视频 | 黄色美女网站免费看 | 欧美成人免费全部观看天天性色 | 草草影院永久在线观看 | 日本成人免费观看 | 91精品一区二区三区在线观看 | 成人欧美一区二区三区视频xxx | 午夜香蕉成视频人网站高清版 | 欧美另类专区 | 久久久日本久久久久123 | 99视频在线观看视频 | 欧美黄色成人 | 一级片久久 | 国产高清精品久久久久久久 | 日韩精品一级毛片 | 韩国特级毛片 | 一区二区三区在线播放 | 欧美成人高清在线视频大全 | 亚洲免费一级片 | 欧美一级毛片兔费播放 | 韩国精品一区二区三区在线观看 | 免费国产不卡午夜福在线 | 国产成人影院在线观看 | 91精品啪在线看国产网站 | 欧美一级毛片一级 | 毛片在线全部免费观看 | 久久亚洲精品无码观看不卡 | 亚洲高清国产一区二区三区 | 一区二区三区精品国产 | 国产一级做a爱片久久毛片a |