ON DUPLICATE KEY update uid = uid AND fan_id = fan_id
都不用加, SQLAlchemy 會(huì)用它選的那個(gè)實(shí)現(xiàn)而已。
innodb普通索引末尾都會(huì)帶上主鍵值
查詢主鍵直接在索引段上就可以完成
查詢其他字段會(huì)先根據(jù)索引找到主鍵值,再根據(jù)主鍵查找聚簇索引找到你要的字段
測(cè)試用例:
CREATE TABLE `test` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`months` varchar(7) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8;
insert into `test`(`id`,`months`) values
(1,'2018-01'),
(2,'2017-12'),
(3,'2017-11');
查詢語句
SELECT months AS WhichMonth,(SELECT DAY(LAST_DAY(CONCAT(months,'-01')))) AS TotalDays FROM test GROUP BY months
測(cè)試結(jié)果:
可以考慮JS先壓縮, 數(shù)據(jù)庫存訪問路徑
http://www.jianshu.com/p/6a45...
時(shí)區(qū)問題,正好差8小時(shí),參考https://www.cnblogs.com/wajik...
mysql正常監(jiān)聽3306端口,如果在docker容器里面可以連接的話,證明docker環(huán)境端口已經(jīng)打開。
那么在外面連接不上的原因:可能是docker端口沒有映射到宿主機(jī)上。
解決方案:
宿主機(jī)為Linux環(huán)境的話,直接在docker run 命令中使用 -p 3306:3306映射即可
宿主機(jī)為windows環(huán)境的話,使用上述命令做好映射之后,還需要查找一下docker虛擬機(jī)的ip進(jìn)行連接
命令為:docker-machine ip default
原因是:docker是運(yùn)行在Linux上的,在Windows中運(yùn)行docker,實(shí)際上還是在Windows下先安裝了一個(gè)Linux環(huán)境,然后在這個(gè)系統(tǒng)中運(yùn)行的docker。也就是說,服務(wù)中使用的localhost指的是這個(gè)Linux環(huán)境的地址,而不是我們的宿主環(huán)境Windows。
https://www.ibm.com/developer...
可以參考一下這篇文章。
感覺你講的數(shù)據(jù)庫,redis之類的是由具體的PlatformTransactionManager
決定的,比如數(shù)據(jù)庫相關(guān)的事務(wù)管理是由DataSourceTransactionManager
實(shí)現(xiàn)的。而spring也提供了jpa相關(guān)的數(shù)據(jù)庫事務(wù)管理實(shí)現(xiàn)。所以如果redis配置的是支持事務(wù),并且作為數(shù)據(jù)源加入了項(xiàng)目中,它會(huì)和別的事務(wù)一樣一起回滾的。
PlatformTransactionManager
還有以下多種實(shí)現(xiàn)。
但是至于像數(shù)組操作的這樣的操作,它是不會(huì)回滾的。因?yàn)槭紫仁聞?wù)的概念本身就是針對(duì)數(shù)據(jù)庫的操作而產(chǎn)生的,而回滾則是為了確保一組數(shù)據(jù)庫操作能夠同時(shí)實(shí)現(xiàn)或是同時(shí)不實(shí)現(xiàn)。比如mysql就會(huì)根據(jù)log來執(zhí)行回滾操作。但是數(shù)組并不屬于事務(wù)定義的范圍啊。當(dāng)然啦,你也可以使用動(dòng)態(tài)代理自己實(shí)現(xiàn)數(shù)組回滾這種啦。
======================作者的解答=================================
在步驟installation的時(shí)候先執(zhí)行exector.
然后再product configuration 就不會(huì)爆上訴錯(cuò)誤提示了
model.update({},{$set:{node:node}},{multi:true});
mysql 8.0嗎?看下這個(gè)
https://segmentfault.com/n/13...
我也不知道,我只能提供思路。vscode本身是可以安裝插件的,也就是說,你可以去vscode的官方插件文檔里找找,看有沒有專門提供api。沒有的話,就去看vscode的源碼,看看它的rename symbol選項(xiàng)綁定了哪個(gè)函數(shù),就像分析一個(gè)網(wǎng)頁的行為一樣——vscode本來也就是個(gè)網(wǎng)頁。實(shí)在不行,就自己實(shí)現(xiàn)rename symbol的功能,或者干脆點(diǎn)用正則表達(dá)式在文件范圍內(nèi)replace,應(yīng)該不至于會(huì)把不該替換的替換掉吧。
個(gè)人覺得可以從并發(fā)角度來理解,如:原version
值為1,同時(shí)發(fā)生了兩個(gè)更新請(qǐng)求,version
都是2,語句一的后果可能是兩次更新后,version
是2,語句二的后果應(yīng)該是兩次更新后,version
是3。
語句一和語句二的另一個(gè)差別在于,語句一表示只要當(dāng)前version
比原version
大即可更新,而語句二表示必須基于某一指定version
才能更新,如:原version
為1,語句一表示當(dāng)前version
無論是2還是5都可以更新,而語句二表示只有傳入更新條件中舊版本號(hào)為1才能更新。不過這點(diǎn)的好處我倒是沒看出來。
User.
findOne({ name: 'Val' }).
populate({
path: 'friends',
// Get friends of friends - populate the 'friends' array for every friend
populate: { path: 'friends' }
});
UserSerializer里的owner應(yīng)該在SnippetSerializer中吧
不知這么寫能否讓你理解一下nextTick
的用途:
mounted(){
this.init();
},
methods:{
init(){
axios.get('/users/addressList').then((response)=>{
var res=response.data;
if(res.status==='0'){
this.addressList=res.result;
this.addressList.forEach((item)=>{
if(item.isDefault){
this.selectedId=item.addressId;
}
});
this.$nextTick(function() {
//在這里執(zhí)行的代碼表示從服務(wù)器返回的數(shù)據(jù)已經(jīng)賦值到data中,并且已經(jīng)更新了相應(yīng)頁面中綁定的值,這時(shí)候就可以使用這個(gè)方法來執(zhí)行其它函數(shù)或者功能
})
}
})
}
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>html5實(shí)現(xiàn)上傳</title>
<script src="https://cdn.bootcss.com/jquery/3.3.1/jquery.min.js"></script>
</head>
<body>
<div id = "result"></div>
<input id="pic" type="file" name = 'pic' accept = "image/*" onchange = "selectFile()"/>
<script type="text/javascript">
var form = new FormData();//通過HTML表單創(chuàng)建FormData對(duì)象
var url = '127.0.0.1:8080/'
function selectFile(){
var files = document.getElementById('pic').files;
if(files.length == 0){
return;
}
var file = files[0];
//把上傳的圖片顯示出來
var reader = new FileReader();
// 將文件以Data URL形式進(jìn)行讀入頁面
reader.readAsBinaryString(file);
reader.onload = function(f){
var result = $("#result");
var src = "data:" + file.type + ";base64," + window.btoa(this.result);
result.append($('<img src ="'+src+'"/>'));
}
form.append('file',file);
}
</script>
</body>
</html>
代碼源自這里,稍作修改,希望可以幫到你
假若需要考慮兼容性,推薦使用插件,如WebUploader,一般的組件庫都會(huì)包含上傳插件
北大青鳥APTECH成立于1999年。依托北京大學(xué)優(yōu)質(zhì)雄厚的教育資源和背景,秉承“教育改變生活”的發(fā)展理念,致力于培養(yǎng)中國(guó)IT技能型緊缺人才,是大數(shù)據(jù)專業(yè)的國(guó)家
北大青鳥中博軟件學(xué)院創(chuàng)立于2003年,作為華東區(qū)著名互聯(lián)網(wǎng)學(xué)院和江蘇省首批服務(wù)外包人才培訓(xùn)基地,中博成功培育了近30000名軟件工程師走向高薪崗位,合作企業(yè)超4
中公教育集團(tuán)創(chuàng)建于1999年,經(jīng)過二十年潛心發(fā)展,已由一家北大畢業(yè)生自主創(chuàng)業(yè)的信息技術(shù)與教育服務(wù)機(jī)構(gòu),發(fā)展為教育服務(wù)業(yè)的綜合性企業(yè)集團(tuán),成為集合面授教學(xué)培訓(xùn)、網(wǎng)
達(dá)內(nèi)教育集團(tuán)成立于2002年,是一家由留學(xué)海歸創(chuàng)辦的高端職業(yè)教育培訓(xùn)機(jī)構(gòu),是中國(guó)一站式人才培養(yǎng)平臺(tái)、一站式人才輸送平臺(tái)。2014年4月3日在美國(guó)成功上市,融資1
浪潮集團(tuán)項(xiàng)目經(jīng)理。精通Java與.NET 技術(shù), 熟練的跨平臺(tái)面向?qū)ο箝_發(fā)經(jīng)驗(yàn),技術(shù)功底深厚。 授課風(fēng)格 授課風(fēng)格清新自然、條理清晰、主次分明、重點(diǎn)難點(diǎn)突出、引人入勝。
曾工作于聯(lián)想擔(dān)任系統(tǒng)開發(fā)工程師,曾在博彥科技股份有限公司擔(dān)任項(xiàng)目經(jīng)理從事移動(dòng)互聯(lián)網(wǎng)管理及研發(fā)工作,曾創(chuàng)辦藍(lán)懿科技有限責(zé)任公司從事總經(jīng)理職務(wù)負(fù)責(zé)iOS教學(xué)及管理工作。
精通HTML5和CSS3;Javascript及主流js庫,具有快速界面開發(fā)的能力,對(duì)瀏覽器兼容性、前端性能優(yōu)化等有深入理解。精通網(wǎng)頁制作和網(wǎng)頁游戲開發(fā)。
具有10 年的Java 企業(yè)應(yīng)用開發(fā)經(jīng)驗(yàn)。曾經(jīng)歷任德國(guó)Software AG 技術(shù)顧問,美國(guó)Dachieve 系統(tǒng)架構(gòu)師,美國(guó)AngelEngineers Inc. 系統(tǒng)架構(gòu)師。