不輸入的話不就是null了嗎?
按你的使用場景,推送數(shù)據(jù)必須得在數(shù)據(jù)創(chuàng)建事務(wù)成功之后執(zhí)行,這里必須有個(gè)先后。你可以將推送這個(gè)操作異步執(zhí)行,消息隊(duì)列有一搬有ack機(jī)制,確保消息沒丟失。這時(shí)候監(jiān)聽消息隊(duì)列的程序會執(zhí)行推送,如果推送成功做標(biāo)記。如果推送失敗也標(biāo)記記錄時(shí)間,也可以推到另一個(gè)消息隊(duì)列約定多少分鐘重試。實(shí)在不行就徹底標(biāo)記失敗,或者回滾之前創(chuàng)建的數(shù)據(jù)。這個(gè)才是最終一致性。
如果是并行的操作,就得使用消息隊(duì)列的confirm機(jī)制了。
查一下文檔:
不必要更新所有數(shù)據(jù),因?yàn)槿绻潞芏嗥渌麩o用的數(shù)據(jù)的話,后期如果數(shù)據(jù)很多,會有很多的資源浪費(fèi),因?yàn)槟阋淮尾僮髯疃嗍?條數(shù)據(jù)狀態(tài)的切換,比如,當(dāng)前選中的是4,你想切換到25,其實(shí)是4的state變成0,25的state變成1.所以,你只需要向后臺傳一個(gè)這樣的json:
{
4:0,
25:1
}
json_decode 轉(zhuǎn)換之后的數(shù)組格式為這樣
$req = [4=>0,25=>1]
然后foreach處理
foreach($req as $key => $re) {
$db->where('id', '=', $key)->update(['state' => $re]);
}
因?yàn)樽疃嘀挥袃纱窝h(huán),所以對性能影響并不是很大。
或者可以這樣,需要將數(shù)據(jù)用array_keys ,array_values 處理一下。
/**
* update `表名` set state = case id
* when 4 then 0
* when 25 then 1
* end where id in (4,25)
* @param $table 表名
* @param $conditions_field 條件字段,此處為 id
* @param $values_field 需要被更新的字段 ,此處為state
* @param $conditions 條件 [4,25]
* @param $values 被更新的值 [0,1]
* @return int
*/
public function batchUpdate($table,$conditions_field, $values_field, $conditions, $values)
{
$sql = 'update ' . $table . ' set '. $values_field .' = case ' .$conditions_field;
foreach ($conditions as $key => $condition) {
$sql .= ' when ' . $condition . ' then ?';
}
$sql .= ' end where id in (' . implode(',', $conditions) . ')';
return $db->update($sql, $values);
}
$data = array();
foreach ($chartData as $item) {
if (isset($data[$item['add_time']])) {
$data[$item['add_time']]['number'] += $item['viewTime'];
} else {
$data[$item['add_time']] = array(
'date' => $item['add_time'],
'number' => $item['viewTime']
);
}
}
$data = array_values($data);
echo json_encode($data);既然是用戶自定義,那么在列表顯示之前,需要用戶自定義列表頭
用一個(gè)數(shù)組存儲['字段名'=>'顯示名稱']
[
'字段名1'=>'顯示名稱1',
'字段名2'=>'顯示名稱2'
'字段名3'=>'顯示名稱3'
]
導(dǎo)入過程,用戶自定義導(dǎo)入列
execl列假設(shè)3列: A1,B1,C1
[
'字段名1'=>'A1',
'字段名2'=>'B1',
'字段名3'=>'C1',
]
按照相應(yīng)的規(guī)則導(dǎo)入數(shù)據(jù)
你這么說真的很為難,不過也不是不可以,你先生成對應(yīng)日期的虛擬表,然后依據(jù)這個(gè)虛擬表中的日期,進(jìn)行 where 條件查詢。嗯,就是這么簡單,應(yīng)該要寫個(gè)存儲過程吧,因?yàn)樵诖鎯^程外是不允許循環(huán)的。當(dāng)然了,并不建議你這么做,因?yàn)楹苋菀兹聿樵?。建議,統(tǒng)計(jì)好對應(yīng)數(shù)據(jù)再交由程序進(jìn)行遍歷,如果空缺,默認(rèn)設(shè)置顯示當(dāng)天為空就好。
描述得不是很明白,不過看了下你的 sql 中并沒有存在mysql 中的去重 distinct 或者 group by 操作,如果你是不知道這兩個(gè)方法,可以自行了解下。這個(gè)應(yīng)該能滿足你說的,不同 store_id 。
當(dāng)然,也可能你是其它需求,這樣的話,你可能需要描述得更清楚些,才能讓大家能對你提供有效的建議。
你可以用interface 然后 反射看看對應(yīng)的類型
謝謝各位的回答,我已經(jīng)找到問題,是由于mongo在做數(shù)據(jù)操作的時(shí)候需要實(shí)例化一個(gè)bluk對象,這個(gè)對象我只實(shí)例化了一次,改為每次循環(huán)都實(shí)例化就好使了
host是localhost,那么會使用UNIX domain socket方式連接數(shù)據(jù)庫,這也就意味著需要一個(gè)socket文件,如/tmp/mysql.sock。ctrl+f 搜索mysql替換為mysqli
找到原因了,是因?yàn)樵陬^文件里面加上了
<meta http-equiv="Content-Security-Policy" content="upgrade-insecure-requests" />
自動(dòng)將http的不安全請求升級為https,所以請求全都變成https了
簡單理解就是聚集索引物理順序存儲,非聚集索引隨機(jī)存儲
這里的存儲是索引到的數(shù)據(jù)行,而非索引段本身
from accounts.models import User
accounts.models里有定義User模型么?
使用字段數(shù)組長度條件滿足了需求
db.data.find( { test: { $size: 1 } } )問題一
可能是數(shù)組上的索引,也就是Multikey Index。這是正常的。一個(gè)文檔的數(shù)組有多少個(gè)元素就有多少個(gè)key。
問題二
如果符合條件的一共只有31條,不就是31了嗎?
map方法返回的是一個(gè)新數(shù)組,不會改變原來的數(shù)組
this.opts = [1,2];
let result = this.opts.map(item => item*12)
console.log(result)time 字段 需要設(shè)成timestamp類型就可以了
EDITED
insert into t_B(id, name,time)
select id, name, now() from t_A異常捕獲不對應(yīng)該這樣寫,需要結(jié)合第一句你需要查詢的語句一起寫:
try:
hostLi = session.query(database.DB_test.host).all()
except:
session.rollback()北大青鳥APTECH成立于1999年。依托北京大學(xué)優(yōu)質(zhì)雄厚的教育資源和背景,秉承“教育改變生活”的發(fā)展理念,致力于培養(yǎng)中國IT技能型緊缺人才,是大數(shù)據(jù)專業(yè)的國家
達(dá)內(nèi)教育集團(tuán)成立于2002年,是一家由留學(xué)海歸創(chuàng)辦的高端職業(yè)教育培訓(xùn)機(jī)構(gòu),是中國一站式人才培養(yǎng)平臺、一站式人才輸送平臺。2014年4月3日在美國成功上市,融資1
北大課工場是北京大學(xué)校辦產(chǎn)業(yè)為響應(yīng)國家深化產(chǎn)教融合/校企合作的政策,積極推進(jìn)“中國制造2025”,實(shí)現(xiàn)中華民族偉大復(fù)興的升級產(chǎn)業(yè)鏈。利用北京大學(xué)優(yōu)質(zhì)教育資源及背
博為峰,中國職業(yè)人才培訓(xùn)領(lǐng)域的先行者
曾工作于聯(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é)及管理工作。
浪潮集團(tuán)項(xiàng)目經(jīng)理。精通Java與.NET 技術(shù), 熟練的跨平臺面向?qū)ο箝_發(fā)經(jīng)驗(yàn),技術(shù)功底深厚。 授課風(fēng)格 授課風(fēng)格清新自然、條理清晰、主次分明、重點(diǎn)難點(diǎn)突出、引人入勝。
精通HTML5和CSS3;Javascript及主流js庫,具有快速界面開發(fā)的能力,對瀏覽器兼容性、前端性能優(yōu)化等有深入理解。精通網(wǎng)頁制作和網(wǎng)頁游戲開發(fā)。
具有10 年的Java 企業(yè)應(yīng)用開發(fā)經(jīng)驗(yàn)。曾經(jīng)歷任德國Software AG 技術(shù)顧問,美國Dachieve 系統(tǒng)架構(gòu)師,美國AngelEngineers Inc. 系統(tǒng)架構(gòu)師。