下載本文檔
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、使用Python向MySQL數(shù)據(jù)庫中存入json類型數(shù)據(jù)0.說明因?yàn)槌鲇趥€(gè)人項(xiàng)目的需要,獲取到的數(shù)據(jù)都是json類型的,并且都要存入MySQL數(shù)據(jù)庫中,因?yàn)閖son類型數(shù)據(jù)不像一般的文本數(shù)據(jù),所以在存入MySQL時(shí)需要注意的問題很多。在網(wǎng)上找了很多方法,整理了一下比較實(shí)用可靠的,總結(jié)下來就是下面的過程:MySQL表中需要保證存儲(chǔ)json數(shù)據(jù)的列類型為BLOB;使用sql語句時(shí),使用MySQLdb.excape_string函數(shù)來對(duì)json數(shù)據(jù)進(jìn)行轉(zhuǎn)義;查詢數(shù)據(jù)時(shí),將結(jié)果使用json.loads就能夠得到原來的Python數(shù)據(jù)類型;下面就來實(shí)戰(zhàn)一下,實(shí)際上,在我的需求中,我需要將Python中的
2、字典存入MySQL,所以只能先將其轉(zhuǎn)換為json來處理。1實(shí)戰(zhàn)存儲(chǔ)json數(shù)據(jù)到MySQL中(1)數(shù)據(jù)存儲(chǔ)1創(chuàng)建能存儲(chǔ)json數(shù)據(jù)類型的數(shù)據(jù)庫表mysqlcreatetablejsondata-(-idint(6)auto_incrementprimarykey,-datablob(1024)-);QueryOK,0rowsaffected(0.25sec)mysqlshowtables;TOC o 1-5 h z+|Tables_in_spyinux|+|jsondata|test|+2rowsinset(0.00sec)mysqldescribejsondata;+|Field|Type|
3、Null|Key|Default|Extra|+|id|int(6)|NO|PRI|NULL|autoncrement|data|blob|YES|NULL|+2rowsinset(0.00sec)2.使用Python生成json數(shù)據(jù)類型importjsond=name:xpleaftype(d)d_json=json.dumps(d)d_jsonname:xpleaftype(d_json)3使用MySQLdb連接MySQL數(shù)據(jù)庫importMySQLdbconn=m.connect(host=localhost,port=3306,user=root,passwd=123456,db=sp
4、yinux)cur=conn.cursor()4寫原生sql語句tsql=insertintojsondata(data)values(json);5.使用MySQLdb方法轉(zhuǎn)義json數(shù)據(jù)sql=tsql.format(json=MySQLdb.escape_string(dson);sqlinsertintojsondata(data)values(name:xpleaf)6.執(zhí)行sql語句cur.execute(sql)cur.execute(sql)2)數(shù)據(jù)查詢上面的操作完成之后,我們已經(jīng)成功將json的數(shù)據(jù)存取到MySQL中,關(guān)鍵是能不能將該數(shù)據(jù)取出來,并且最后還原成Python的字
5、典類型類型。1先在MySQL中查詢存儲(chǔ)的數(shù)據(jù)mysqlselect*fromjsondata;TOC o 1-5 h z+|id|data|+|1|name:xpleaf|+1rowinset(0.00sec)2在Python交互器中查詢數(shù)據(jù)cur.execute(select*fromjsondata);1Lmydata=cur.fetchall()mydata(1L,name:xpleaf),)mydata=mydata01mydataname:xpleaftype(mydata)3使用json.loads解析json數(shù)據(jù)mydata=json.loads(mydata)mydatauname:uxpleaftype(mydata)mydatanameuxpleafmydata.get(name)uxpleaf可以看到,最開始我們使用Pythonn創(chuàng)建了一個(gè)字典類型的數(shù)據(jù),之后將其轉(zhuǎn)換為json數(shù)據(jù)類型,以便于存入MySQL中,在這個(gè)過程中需要使用MySQL.escape_string方法來對(duì)json數(shù)據(jù)進(jìn)行轉(zhuǎn)義,最后查詢數(shù)據(jù)時(shí),我們使用json.loads方法來解析json數(shù)據(jù),從而得到我們最開始存儲(chǔ)的Python字典類
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2023-2024學(xué)年浙江攝影版(三起)(2020)小學(xué)信息技術(shù)六年級(jí)上冊(cè) 第二單元第14課 綜合應(yīng)用(說課稿)
- 2024秋七年級(jí)英語下冊(cè) Module 3 Making plans Unit 1 What are you going to do at the weekends說課稿 (新版)外研版
- 2024-2025學(xué)年新教材高中政治 第一單元 探索世界與把握規(guī)律 2.2 運(yùn)動(dòng)的規(guī)律性說課稿 部編版必修4
- 2024-2025學(xué)年新教材高中歷史 第二單元 中古時(shí)期的世界 第4課 中古時(shí)期的亞洲教學(xué)說課稿 新人教版必修《中外歷史綱要(下)》
- 7 《包身工》 說課稿 2024-2025學(xué)年統(tǒng)編版高中語文選擇性必修中冊(cè)001
- 二零二五年酒店集團(tuán)客房預(yù)訂合作協(xié)議3篇
- 2024年高中語文 第8課 寡人之于國也說課稿8 新人教版必修3
- 2024年春七年級(jí)生物下冊(cè) 第四單元 第一章 第三節(jié) 青春期說課稿 (新版)新人教版
- 2024-2025學(xué)年高中物理 第四章 機(jī)械能和能源 第2節(jié) 動(dòng)能 勢(shì)能說課稿1 粵教版必修2
- 流域綜合治理合同(2篇)
- Unit6AtthesnackbarStorytimeDiningwithdragons(課件)譯林版英語四年級(jí)上冊(cè)
- 2023年四川省公務(wù)員錄用考試《行測(cè)》真題卷及答案解析
- 機(jī)電一體化系統(tǒng)設(shè)計(jì)-第5章-特性分析
- 2025年高考物理復(fù)習(xí)壓軸題:電磁感應(yīng)綜合問題(原卷版)
- 雨棚鋼結(jié)構(gòu)施工組織設(shè)計(jì)正式版
- 醫(yī)院重點(diǎn)監(jiān)控藥品管理制度
- 2024尼爾森IQ中國本土快消企業(yè)調(diào)研報(bào)告
- 2024年印度辣椒行業(yè)狀況及未來發(fā)展趨勢(shì)報(bào)告
- 骨科醫(yī)院感染控制操作流程
- 鑄鋁焊接工藝
- 《社區(qū)康復(fù)》課件-第六章 骨關(guān)節(jié)疾病、損傷患者的社區(qū)康復(fù)實(shí)踐
評(píng)論
0/150
提交評(píng)論