鍍金池/ 問答/ 數(shù)據(jù)庫問答
懶洋洋 回答
  1. 該表我覺得沒有必要加begin_date、end_date字段
  2. 對于價(jià)格隨時(shí)間變動的應(yīng)該吧price、begin_dateend_date和相應(yīng)的房型組成一個(gè)新的表
  3. 查詢的時(shí)候根據(jù)當(dāng)前或者選中的時(shí)間查詢2中的表,命中則使用2表中的價(jià)格,未命中則使用1表中的默認(rèn)價(jià)格。
  4. 這樣一個(gè)房型可以有多個(gè)價(jià)格區(qū)間,可以達(dá)到定制某個(gè)時(shí)間段的價(jià)格,甚至可以疊加,比如7月-10月價(jià)格100,但是七夕價(jià)格10,取最新的值就好了,或者標(biāo)記置頂?shù)闹怠?/li>
雨萌萌 回答

建議做成異步隊(duì)列,當(dāng)某個(gè)條件觸發(fā)時(shí)候往對接丟數(shù)據(jù),然后進(jìn)行計(jì)算,也不一定等到凌晨計(jì)算我現(xiàn)在也是分紅方案,我這邊是當(dāng)用戶充值時(shí)候,寫入隊(duì)列,異步計(jì)算。隊(duì)列我采用是beanstalked 隊(duì)列支持?jǐn)?shù)據(jù)持久化

墨染殤 回答

出現(xiàn)亂碼是因?yàn)榫幋a與解碼使用的格式不一致,需要修改數(shù)據(jù)庫與代碼的中的編碼格式:

1.查看數(shù)據(jù)庫使用的編碼設(shè)置 一般使用utf-8 
(數(shù)據(jù)庫編碼設(shè)置參考:https://www.cnblogs.com/liyingxiang/p/5877764.html)
2.查看代碼的編碼格式,并與數(shù)據(jù)庫統(tǒng)一
3.命令行有個(gè)單獨(dú)的僅限當(dāng)前控制臺的編碼設(shè)置
    set names gbk /set names uft8 
熟稔 回答

《MYSQL內(nèi)核:INNODB存儲引擎》和《高性能MySQL》都有相關(guān)內(nèi)容

這幾篇文章或許也能幫到你

[Mysql]——通過例子理解事務(wù)的4種隔離級別:
https://www.cnblogs.com/snsdz...

數(shù)據(jù)庫并發(fā)的五個(gè)問題以及四級封鎖協(xié)議與事務(wù)隔離的四個(gè)級別
http://blog.csdn.net/zhangzey...

壞脾滊 回答

不傳type的時(shí)候請求是不是這樣的 localhost:3000/admin/metas/list?type=

巴扎嘿 回答

oracle日期類型可以直接加減,沒有add_days這個(gè)函數(shù),如:

select sysdate - 1 from dual;

返回結(jié)果是昨天的當(dāng)前時(shí)間點(diǎn)

你好胸 回答
select * from table_1 RIGHT JOIN table_2 ON table_1.id = table_2.uid
where table_1.status = 1 AND table_2.level_id = 1 AND table_2.level_id = 2

這段代碼意思是同一條table2的記錄同時(shí)是等級1和等級2,是個(gè)假命題。。
改的話需要right join兩次table2

select table_1.* from table_1 
RIGHT JOIN table_2 t2Lv1 ON table_1.id = t2Lv1.uid ON t2Lv1.level_id = 1
RIGHT JOIN table_2 t2Lv2 ON table_1.id = t2Lv2.uid ON t2Lv2.level_id = 2
where table_1.status = 1
GROUP BY table_1.id

大致思路就是這樣

悶騷型 回答

keyword那一行的結(jié)尾是一個(gè)中文逗號么

情皺 回答

sql1的 LIMIT 是全表掃描
sql2似乎是把結(jié)果存到緩存里, 再掃描.

我遇到過limit大表慢的情況, 但不用分組, 開始用的id查, 后來改游標(biāo)了.

兔寶寶 回答

raw data 就是整行的內(nèi)容啊。
例如,一個(gè)表有(id, column2, column3, ... , columnN)這N行,那么主鍵索引就是:

id -> (column2, column3, ... , columnN)

如果你只對column2做一個(gè)一般的索引,那么這個(gè)索引是:

column2 -> id

顯然后者查詢速度回比前者快得多。

舊言 回答

我也碰到類似的警告。 說是某某函數(shù)被棄用。 有些是可以忽略的。

情殺 回答

設(shè)置一個(gè)定時(shí)器,剛開始讓所有的table的div都顯示,在頁面打開若干秒或者毫秒之后,讓不該顯示的div隱藏就好了hide(),目前完美解決,后續(xù)有問題再續(xù)問

絯孑氣 回答

個(gè)人理解如果數(shù)據(jù)庫是這么設(shè)計(jì)的話,初衷是讓在應(yīng)用程序中處理:按照逗號分隔,逐條查詢r(jià)ule表,更常規(guī)的做法是用一個(gè)用戶和規(guī)則的關(guān)聯(lián)表。

如果非要用sql做關(guān)聯(lián)查詢,可以用FIND_IN_SET,不過效率不會太高。

select *
from 
(select '1,2,3,4,5' ids) t1 inner join (select 1 id, '張三' name union select 2, '李四') t2 
on FIND_IN_SET(t2.id, t1.ids) > 0
陌璃 回答

1.對于key idx(user_id, user_name)
如果查詢語句是這樣的 select * from mytable where user_id = 1; 這樣索引是生效的.
如果查詢語句是這樣的 select * from mytable where user_name = "tom"; 這樣索引是不生效的.

這是組合索引的最左優(yōu)先原則. 索引的第一個(gè)字段必須出現(xiàn)在查詢語句中.
兩個(gè)區(qū)別是 : 用user_i字段查詢多還是用user_name字段查詢多.

我不懂 回答

WHERE 1=1 and out_status = 0 and name != '' and name is not null

情未了 回答

試試加這個(gè)配置:

spring.jpa.show-sql=true
筱饞貓 回答

你好 我想咨詢一下 我開啟了think queue:listen之后 電腦就變得特別卡 是因?yàn)槲曳?wù)器的配置太低了么