鍍金池/ 問答/ 數(shù)據(jù)庫問答
怪痞 回答

select

(select value from a where stime = (select max(stime) from a))
- 
(select value from a where stime = (select min(stime) from a));
誮惜顏 回答

這實(shí)際上是沒有問題的,因?yàn)槟阌行聰?shù)據(jù)了啊,那原來的第一頁本來就是跑到第二頁了,所以你取第二頁就是原來的10條數(shù)據(jù)。如果為了防止新數(shù)據(jù)的干擾,可以帶上多一個(gè)條件,比如插入時(shí)間是從什么時(shí)間之前的,或者_(dá)id是從哪里開始。
關(guān)于多加一個(gè)條件:

  • _id的默認(rèn)值是ObjectId,它實(shí)際上是帶有時(shí)間戳的;

  • 所以在查詢時(shí)多加一個(gè)條件{_id: {$lt: <id>}}就可以保證新的數(shù)據(jù)不會被查出來

這個(gè)問題實(shí)際跟MongoDB也無關(guān)的,使用關(guān)系數(shù)據(jù)庫一樣會出現(xiàn)這樣的情況,那么關(guān)系數(shù)據(jù)庫你會如何處理呢?

單眼皮 回答

oracle中sql語句如用了綁定變量,根據(jù)變量采樣數(shù)據(jù)形成的執(zhí)行計(jì)劃,可能會和實(shí)際的數(shù)據(jù)分布不一致,造成性能低下。
字符串拼接形成的sql不存在此類問題,但會帶來硬解析過多,在并行執(zhí)行sql多的情況會嚴(yán)重影響數(shù)據(jù)庫整體性能。

如果能確認(rèn)合理的執(zhí)行計(jì)劃,可以通過hints或outline固化執(zhí)行計(jì)劃。

執(zhí)念 回答
  1. 使用DBRef可以達(dá)到外鍵效果,但是你也可以通過設(shè)置關(guān)系字段來實(shí)現(xiàn)。
  2. MongoDB的_id是自增的——但不是整數(shù)自增。這里的自增只指MongoDB的_id原理確實(shí)與先后順序有關(guān),但是由于類型是獨(dú)有的ObjectId,因此無法通過常規(guī)思路去處理。事實(shí)上ObjectId你可以當(dāng)作是一個(gè)索引中的一個(gè)key,其對應(yīng)的是一個(gè)timestamp。但是有個(gè)小小問題,在我的記憶里看過一篇文章,當(dāng)文檔更新時(shí),若文檔增長數(shù)據(jù)量超出原來的空間準(zhǔn)備,那么這條數(shù)據(jù)會被刪除,而重新在集尾插入。但是我想,對于ObjectId而言是沒有什么影響的。實(shí)現(xiàn)整數(shù)自增,依然需要代碼邏輯實(shí)現(xiàn)。

    • 創(chuàng)建一個(gè)集合,專門記錄各集合的整數(shù)id高度,每次插入數(shù)據(jù)時(shí)使用記錄高度。
    • 新建字段作為自增id,插入前查詢最近數(shù)據(jù)的id,然后+1插入
  3. 自增用戶時(shí)增加一條訂單,MongoDB的事務(wù)實(shí)現(xiàn)我還沒有更好的頭緒,一般通過代碼邏輯去做。
枕邊人 回答

頁面的鏈接應(yīng)該用絕對路徑,你這可能是相對路徑了,檢查檢查。javaweb類有相應(yīng)的方法

離殤 回答
想請問是這兩個(gè)在一起比mysql更搭配嗎?

并沒有。

網(wǎng)上查找的資料都是node加上mongodb

因?yàn)楹芏嗳?,連基本的 SQL 語句,關(guān)系數(shù)據(jù)庫模式的概念,都不會。

筱饞貓 回答

大致意思就是,你可以用mongoose添加和設(shè)置虛擬屬性,但是這虛擬屬性的值不會保存到數(shù)據(jù)庫中。
比如,前臺傳到后臺一個(gè)參數(shù)name,代表用戶的名稱,但是數(shù)據(jù)庫保存的是兩個(gè)字段,姓和名,這就可以用虛擬屬性

// 數(shù)據(jù)庫中緩存的格式
var schema = new Schema({
    name: {
        first: { 'type': String },  
        last: { 'type': String },
      }
});

// 當(dāng)獲取該 schema 的fullname屬性時(shí),將 schema 中的 name.first 和 name.last 拼接起來返回
var virtual = schema.virtual('fullname');
virtual.get(function () {
  return this.name.first + ' ' + this.name.last;
});
// 當(dāng)設(shè)置該schema的 fullname 屬性時(shí),將設(shè)置的字以空格分開,分別賦值給 schema 中的 name.first 和 name.last 屬性
var virtual = schema.virtual('fullname');
virtual.set(function (v) {
  var parts = v.split(' ');
  this.name.first = parts[0];
  this.name.last = parts[1];
});

// 將該 schema 保存到數(shù)據(jù)庫中時(shí),只會保存 name.first 和 name.last
// fullname屬性的值不會保存到數(shù)據(jù)庫中,這就是virtual

http://mongoosejs.com/docs/ap...

set 中的 function 的參數(shù) v,是設(shè)置虛擬屬性時(shí)的值.不保存到數(shù)據(jù)庫中,但是它也是有存在的意義的,比如,就像例子中的,在用戶看來,它只有一個(gè)名字,但是在數(shù)據(jù)庫中,是要保存姓和名,因?yàn)榉譃樾蘸兔?我們后續(xù)可以對用戶做統(tǒng)計(jì),姓張的多少人.(這也只是舉個(gè)例子).

再比如,訂單的狀態(tài),數(shù)據(jù)庫中保存的是0,1,2,3,4,5,6,7.但是在頁面上,顯示的是未支付,已付款,待發(fā)貨,已發(fā)貨,待收貨,已完成,待評價(jià)等.我們就可以設(shè)置一個(gè)虛擬屬性

var virtual = schema.virtual('statusName');
virtual.get(function () {
  switch(this.status){
     case 0: return '待發(fā)貨';
     case 1: return '待收獲';
     case 2: return '已完成';
     default: return '待支付';
  }
  return this.name.first + ' ' + this.name.last;
});
離夢 回答

a3dc963c2f75997cf82d506776cd4e37

大濕胸 回答

拼寫錯(cuò)了

exports.create = ...
遲月 回答

最后用的是sqlsrv自帶的HASHBYTES('SHA1',$str) ,然后插入。

帥到炸 回答

lz今天再次調(diào)試的時(shí)候, 因?yàn)殚_始出現(xiàn)了一個(gè)Servlet沒有找到, 就順手clean了下Tomcat和項(xiàng)目的緩存, 然后再次調(diào)試, 居然詭異般的好了...
哎 , 無心插柳柳成蔭, 里面的機(jī)制太讓人費(fèi)解了.

咕嚕嚕 回答

select ls.id, c.name ,ls.value, ls.toCityId ,d.name from line_state ls inner join city c on

                                                                         ls.fromCityId=c.id
                                                           inner join city d on 
                                                                           ls.toCityId=d.id

order by ls.id asc;

焚音 回答

引入mongoose模塊,查詢指令,user.find({查詢字段:查詢條件}).exec(err,data){}

兔寶寶 回答

mysql重啟就會產(chǎn)生一個(gè)新的binlog文件,在命令行執(zhí)行show binary logs; 查看倒數(shù)第二個(gè)文件就是你重啟前執(zhí)行過的記錄

故人嘆 回答

猜測線上和本地用的根本不是一個(gè)數(shù)據(jù)庫

看一下issue字段的類型吧,是不是在php中是數(shù)字類型,導(dǎo)致執(zhí)行語句變成了:issue=50
在執(zhí)行sql語句前,把綁定變量的值輸出debug日志,對照看一下。

維她命 回答

循環(huán)中做一個(gè)判斷 如果大于6 讓循環(huán)的key初始化