用SQL命令查看Mysql數(shù)據(jù)庫大小
成都創(chuàng)新互聯(lián)公司,為您提供網(wǎng)站建設(shè)、網(wǎng)站制作公司、網(wǎng)站營(yíng)銷推廣、網(wǎng)站開發(fā)設(shè)計(jì),對(duì)服務(wù)塑料袋等多個(gè)行業(yè)擁有豐富的網(wǎng)站建設(shè)及推廣經(jīng)驗(yàn)。成都創(chuàng)新互聯(lián)公司網(wǎng)站建設(shè)公司成立于2013年,提供專業(yè)網(wǎng)站制作報(bào)價(jià)服務(wù),我們深知市場(chǎng)的競(jìng)爭(zhēng)激烈,認(rèn)真對(duì)待每位客戶,為客戶提供賞心悅目的作品。 與客戶共同發(fā)展進(jìn)步,是我們永遠(yuǎn)的責(zé)任!
要想知道每個(gè)數(shù)據(jù)庫的大小的話,步驟如下:
1、進(jìn)入information_schema 數(shù)據(jù)庫(存放了其他的數(shù)據(jù)庫的信息)
use information_schema;
2、查詢所有數(shù)據(jù)的大小:
select concat(round(sum(data_length/1024/1024),2),'MB') as data from tables;
3、查看指定數(shù)據(jù)庫的大?。?/p>
比如查看數(shù)據(jù)庫home的大小
select concat(round(sum(data_length/1024/1024),2),'MB') as data from tables where table_schema='home';
4、查看指定數(shù)據(jù)庫的某個(gè)表的大小
比如查看數(shù)據(jù)庫home中 members 表的大小
select concat(round(sum(data_length/1024/1024),2),'MB') as data from tables where table_schema='home' and table_name='members';
方法一
點(diǎn)擊,電腦桌面上的 開始 --- 選擇 運(yùn)行
在運(yùn)行程序輸入框中輸入 “cmd”(注意不要講引號(hào)也復(fù)制進(jìn)去?。?/p>
進(jìn)入dos界面后,大家再次輸入 ipconfig /all 就會(huì)出現(xiàn)dos界面上邊就有顯示自己的電腦ip地址
方法二
打開打開網(wǎng)絡(luò)和共享中心 查看本地連接,大家也可以直接查看本地連接。這都一樣的
打開,本地連接之后 選擇屬性。 在出現(xiàn)的界面上 選擇“詳細(xì)信息”
在打開的 詳細(xì)信息 之后就會(huì)顯示自己的電腦ip地址了
方法三
百度搜索:ip地址查詢
1、創(chuàng)建數(shù)據(jù)庫表,createtabletest_users(user_idbigint,user_namevarchar(100));
2、查看系統(tǒng)視圖tables,在系統(tǒng)視圖中可以查到剛建的數(shù)據(jù)表,select*frominformation_schema.tablestwheretable_name='test_users',
3、查看系統(tǒng)視圖columns,在系統(tǒng)視圖中可以查到該表所有的字段,select*frominformation_schema.columnstwheretable_name='test_users',
4、查詢表中不存在的字段,執(zhí)行無返回結(jié)果,
select*frominformation_schema.columnst
wheretable_name='test_users'
andcolumn_name='user_id2'
以mysql來說,可能出現(xiàn)臟讀、不可重復(fù)讀以及幻讀,mysql默認(rèn)設(shè)置是可重復(fù)讀,即一次事務(wù)中不會(huì)讀取到不同的數(shù)據(jù)。
可以做如下操作:
1)打開兩個(gè)客戶端,均設(shè)置為RR;
2)在一個(gè)事務(wù)中,查詢某個(gè)操作查到某份數(shù)據(jù);比如是某個(gè)字段version=1存在數(shù)據(jù);
3)在另一個(gè)事務(wù)中,刪除這份version=1的數(shù)據(jù);刪除后,在2所屬的事務(wù)中查詢數(shù)據(jù)是沒有變化的,還是存在version=1的數(shù)據(jù);
4)當(dāng)我們?cè)?所屬的事務(wù)中繼續(xù)更新數(shù)據(jù),那么會(huì)發(fā)現(xiàn)更新不了,明明我們就看到了這份version=1的數(shù)據(jù);
緩存一致性:
緩存一致,與什么一致?是與數(shù)據(jù)庫一致,對(duì)外查詢每個(gè)時(shí)刻一致;所以在針對(duì)于緩存與數(shù)據(jù)庫之間該先更新哪一個(gè)呢?可能有人覺得我先更新數(shù)據(jù)庫,再更新緩存不就行了嗎?但是有想過個(gè)問題嗎?
當(dāng)用戶已經(jīng)支付成功了,更新到數(shù)據(jù)庫,但是呢?你還在緩存中顯示未支付,在用戶點(diǎn)擊頻率很高并且數(shù)據(jù)庫壓力過大,來不及同步到緩存時(shí),那你是不是很尷尬,這就是典型的不一致了。此時(shí)用戶再支付,那你又告訴他已經(jīng)支付了,那他會(huì)把你罵死的
那該怎么來做呢?我們可以這樣,先更新緩存再更新數(shù)據(jù)庫,那么存在什么問題呢?
1)緩存更新成功,但是數(shù)據(jù)庫更新失敗,而被其它的并發(fā)線程訪問到
2)緩存淘汰成功,但是數(shù)據(jù)庫更新失敗,這也會(huì)引發(fā)后期數(shù)據(jù)不一致
MySQL 中不知道從表 怎么通過主表的主鍵查從
--books表中有字段有bId,pId等字段。
--another有bId,pId等字段(create table another select bId,pid,bAuthor from books;--相關(guān)字段以及內(nèi)容來自books表)。
--books和publising建立外鍵,參照publishing中的id字段。
alter table books add constraint FK_books_publishing foreign key (pid) references publishing (id) on update cascade;
--another和publishing之間創(chuàng)建外鍵,參照publishing中的id字段。
alter table another add constraint FK_another_publishing foreign key (pId) references publishing (id) on update cascade;
--舉個(gè)簡(jiǎn)單的更新列子:
update publishing set id = 17,pname = '愛好者' where id='14';
--當(dāng)執(zhí)行這條語句時(shí)(更新publishing表),books表和another表同時(shí)進(jìn)行更新。
--主表更新字段數(shù)據(jù)等,副表也隨之更新,從上面可以看出,主表是publishing,副表是books和another。