課程
/后端開發(fā)
/Java
/Java高并發(fā)秒殺API之業(yè)務(wù)分析與DAO層
select的測試都沒問題,但是 update 的測試一直返回0, 在 sql 里寫出對(duì)應(yīng)的相同的代碼就可以修改數(shù)據(jù)庫,但是在測試類里就無法修改
2017-12-26
源自:Java高并發(fā)秒殺API之業(yè)務(wù)分析與DAO層 4-9
正在回答
update返回0表示你update失敗,通常情況下update都要有where條件的,肯定是where條件不符合導(dǎo)致的,所以應(yīng)該從where條件入手去看問題
我猜:where條件中有中文而且jdbc.jdbcUrl中沒有設(shè)置useUnicode=true&characterEncoding=utf8
僅僅是我的猜測,因?yàn)槲以谶@里碰到過坑
當(dāng)時(shí)我也是update,傳入的where條件中有中文,并且沒有寫utf-8那些參數(shù),所以實(shí)際傳入到數(shù)據(jù)庫的條件變成了亂碼,自然where不匹配,所以失敗了
貼出你的insert代碼和你的jdbc.properties中的jdbc.jdbcUrl的值
舉報(bào)
Java實(shí)現(xiàn)高并發(fā)秒殺API的第一門課,還等什么,趕快來加入吧
1 回答context:property-placeholder標(biāo)簽無效
1 回答Windows下的powershel下mvn命令無效?
4 回答Incorrect table definition; there can be only one TIMESTAMP column with CURRENT_TIMESTAMP in DEFAULT or ON UPDATE clause
2 回答秒殺課程,數(shù)據(jù)庫建立時(shí),為何start_time字段執(zhí)行后,會(huì)自動(dòng)多出default current_timestamp on update current_timestamp?
1 回答求問 :數(shù)據(jù)庫操作update,和insert為什么會(huì)有int的返回值,這個(gè)返回值是什么
Copyright ? 2025 imooc.com All Rights Reserved | 京ICP備12003892號(hào)-11 京公網(wǎng)安備11010802030151號(hào)
購課補(bǔ)貼聯(lián)系客服咨詢優(yōu)惠詳情
慕課網(wǎng)APP您的移動(dòng)學(xué)習(xí)伙伴
掃描二維碼關(guān)注慕課網(wǎng)微信公眾號(hào)
2017-12-26
update返回0表示你update失敗,通常情況下update都要有where條件的,肯定是where條件不符合導(dǎo)致的,所以應(yīng)該從where條件入手去看問題
我猜:where條件中有中文而且jdbc.jdbcUrl中沒有設(shè)置useUnicode=true&characterEncoding=utf8
僅僅是我的猜測,因?yàn)槲以谶@里碰到過坑
當(dāng)時(shí)我也是update,傳入的where條件中有中文,并且沒有寫utf-8那些參數(shù),所以實(shí)際傳入到數(shù)據(jù)庫的條件變成了亂碼,自然where不匹配,所以失敗了
2017-12-26
貼出你的insert代碼和你的jdbc.properties中的jdbc.jdbcUrl的值