เทคนิคการเขียนชุดคำสั่ง SELECT ที่ให้ผู้ใช้ผ่านพารามิเตอร์โดยใช้เครื่องหมายคำถาม เพื่อให้ผู้ใช้กำหนดเงื่อนไขในการค้นหาข้อมูล
การออกแบบฟังก์ชันเพื่อทำงานชุดคำสั่ง SQL ที่ส่งค่ากลับมาเป็น cursor
=== ดาวน์โหลดไฟล์ตัวอย่างได้ที่ https://goo.gl/6J0Gp9
เชิญสมัครเป็นสมาชิกของช่องนี้ได้ที่ https://www.youtube.com/subscription_center?add_user=prasertcbs
► สอน Python 3 การติดต่อกับฐานข้อมูล https://www.youtube.com/watch?v=2n2SLFET-GU&list=PLoTScYm9O0GEdZtHwU3t9k3dBAlxYoq59
► สอน Python https://www.youtube.com/playlist?list=PLoTScYm9O0GH4YQs9t4tf2RIYolHt_YwW
► สอน Python OOP https://www.youtube.com/playlist?list=PLoTScYm9O0GEIZzlTKPUiOqkewkWmwadW
► สอน Python GUI https://www.youtube.com/playlist?list=PLoTScYm9O0GFB1Y3cCmb9aPD5xRB1T11y
► สอน Microsoft SQL Server https://www.youtube.com/playlist?list=PLoTScYm9O0GH8gYuxpp-jqu5Blc7KbQVn
► สอน MySQL https://www.youtube.com/playlist?list=PLoTScYm9O0GFmJDsZipFCrY6L-0RrBYLT
► สอน PostgreSQL https://www.youtube.com/playlist?list=PLoTScYm9O0GGi_NqmIu43B-PsxA0wtnyH
► สอน SQLite https://www.youtube.com/playlist?list=PLoTScYm9O0GHjYJA4pfG38M5BcrWKf5s2
► การเชื่อมต่อกับฐานข้อมูล (SQL Server, MySQL, PostgreSQL, SQLite) ด้วย Python ► https://www.youtube.com/playlist?list=PLoTScYm9O0GEdZtHwU3t9k3dBAlxYoq59
#prasertcbs_SQL #prasertcbs #prasertcbs_python

pyodbc mysql 在 [問題] 從資料庫讀取中文亂碼及空值如何進資料庫- 看板Python 的推薦與評價
最近想要把csv檔或是網路上的檔案連結直接寫進資料庫,感覺終於到了最後一步 卻翻遍
了google都解決不了問題
環境是pythob 3.6.1 ,anaconda 4.4.0
我在jupyter notebook下執行,使用pyodbc連接MySQL
資料來源是網址或是csv檔,我比較習慣用pandas來處理資料
這是我連接資料庫的方法
cn = pyodbc.connect("DRIVER={MySQL ODBC 8.0 ANSI Driver}; SERVER=localhost;
PORT=3306;DATABASE=db; UID=root; PASSWORD=0000;OPTION=3;CHARSET=UTF8;")
cn.setencoding(encoding='utf-8') 這行也不需要了
[解決方法]:
DRIVER 需選擇 Unicode 的版本,從Python連接資料庫取出資料才不會變成亂碼
我不太確定在.connect下放CHARSET=UTF8; 和設定.setencoding(encoding='utf-8')有什
麼不一樣,但是只要少放一個,在insert into時如果有中文,jupyter notebook就會卡
住,都要shutdown kernel再重開才能繼續
現在有個問題就是 我可以順利的新增含有中文的資料到資料庫了,而且在MySQL中select
出來是中文,但是到了python就會變成亂碼,請問我該怎麼解決?
還有個問題就是,我的資料裡面有空值,我寫了個迴圈 配合 .format,讓他逐行新增資
料,但是空值讀出來是nan,沒辦法新增
如果是數字欄位的話,我可以把nan轉成NULL,新增進MySQL就可以是空的,但是如果是文
字的欄位,新增的時候會變成'NULL'而不是空值了
因為我用這樣的形式新增資料
for i in df1.index:
cursor.execute("insert into taichung_201711 values('{}', {});" \
.format(df1.loc[i][6], df1.loc[i][7]))
如果是字串的欄位,一開始就給他''了,要是把NaN改成NULL,就會變成'NULL'進資料庫
有方法可以直接把空值存進MySQL嗎?
這裡我還是把空值都轉成 'NULL'進資料庫,之後調資料出來再轉回nan,
目前都用DataFrame處理資料 還沒發生問題
懇請各位大大指教了
--
※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 111.242.11.7
※ 文章網址: https://www.ptt.cc/bbs/Python/M.1526060186.A.017.html
... <看更多>