python - sqlalchemy更新數據報錯
問題描述
這是我的更新代碼
def alter(self,id,key,value):session = Goods().getsession()session.query(Goods).filter(Goods.id==id).update({key:value})session.close()
但是會報錯
UnicodeEncodeError: ’latin-1’ codec can’t encode characters in position 0-1: ordinal not in range(256)
最新查錯。打印如下
print type(id),type(key),type(value)
<type ’unicode’> <type ’unicode’> <type ’unicode’>127.0.0.1 - - [31/Mar/2017 06:32:05] 'GET /alter?id=1497&key=name&value=%E8%8D%A3%E8%80%80V9+%E6%89%8B%E6%9C%BA+%E9%93%82%E5%85%89%E9%87%91+%E5%85%A8%E7%BD%91%E9%80%9A4G(4G+RAM%2B64G+ROM)%E6%A0%87%E9%85%8D HTTP/1.1' 200 -
初步發現問題所在 數據庫為latin1編碼
然后封裝json的時候UnicodeDecodeError: ’utf8’ codec can’t decode bytes in position 90-91: unexpected end of data
代碼
def get(self):
session = Goods().getsession() goodslist = session.query(Goods) session.close() data = [] for goods in goodslist:tmp = {}tmp[’id’] = goods.idtmp[’name’] = goods.name //這里報錯根源 帶空格tmp[’link’] = goods.linktmp[’price’] = goods.pricetmp[’commit’] = goods.commitdata.append(tmp) jsondata = json.dumps(data) //這里報錯
問題解答
回答1:沒怎么寫過,但是猜測一下
1. 確認你的key和value都不為None2. 更新不用commit么
明顯是數據庫字符集設置有問題,請設置數據庫字符集為UTF-8
如果不想設置數據庫,就解碼待插入的數據 info_str.encode(’你的格式’)再插入
相關文章:
1. 前端 - 關于img父容器的高度會比img的高度多幾像素的問題?2. debian - docker依賴的aufs-tools源碼哪里可以找到啊?3. dockerfile - [docker build image失敗- npm install]4. html5 - 自己的H5頁面如何集成支付寶支付5. php工具中的mysql還是5.1以下的,請問如何才能升級到5.1以上?6. css3 - 沒明白盒子的height隨width的變化這段css是怎樣實現的?7. javascript - 移動端自適應8. Mysql如何按照日期對比數據,求SQL語句9. ios - 類似微博首頁,一張圖的時候是如何確定圖大小的?10. atom開始輸入!然后按tab只有空格出現沒有html格式出現
