鍍金池/ 問答/ 數(shù)據(jù)庫問答
吃藕丑 回答

都不用加, SQLAlchemy 會(huì)用它選的那個(gè)實(shí)現(xiàn)而已。

陌如玉 回答

innodb普通索引末尾都會(huì)帶上主鍵值
查詢主鍵直接在索引段上就可以完成
查詢其他字段會(huì)先根據(jù)索引找到主鍵值,再根據(jù)主鍵查找聚簇索引找到你要的字段

網(wǎng)妓 回答

最大的有符號(hào) BIGINT值是9223372036854775807,檢查一下有沒有溢出
參考官方問題解釋

https://dev.mysql.com/doc/refman/8.0/en/out-of-range-and-overflow.html
維她命 回答

線程框架的一個(gè)重要議題就是線程通信模型,而EDA(Event-Driven Architecture)是一種實(shí)現(xiàn)組件之間松耦合、易擴(kuò)展的更高維度的架構(gòu)方式,我寫過個(gè)一個(gè)線程相關(guān)的項(xiàng)目其中就有這一塊的東西
package com.echo.code.thread.mode.eventloop

陪她鬧 回答

測(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...

愿如初 回答

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)。

clipboard.png

但是至于像數(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ò)誤提示了

練命 回答
  • 在schema上加上node字段
  • 用update語句 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)的好處我倒是沒看出來。

櫻花霓 回答

deep-populate

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ì)包含上傳插件