内射老阿姨1区2区3区4区_久久精品人人做人人爽电影蜜月_久久国产精品亚洲77777_99精品又大又爽又粗少妇毛片

mysql數(shù)據(jù)過(guò)長(zhǎng)怎么辦 mysql 字段太長(zhǎng)

MySQL提示1406-數(shù)據(jù)太長(zhǎng)怎么改都添加不了新數(shù)據(jù)

這個(gè)提示的意思是沒(méi)選擇數(shù)據(jù)庫(kù)。

創(chuàng)新互聯(lián)專(zhuān)注于樺南網(wǎng)站建設(shè)服務(wù)及定制,我們擁有豐富的企業(yè)做網(wǎng)站經(jīng)驗(yàn)。 熱誠(chéng)為您提供樺南營(yíng)銷(xiāo)型網(wǎng)站建設(shè),樺南網(wǎng)站制作、樺南網(wǎng)頁(yè)設(shè)計(jì)、樺南網(wǎng)站官網(wǎng)定制、重慶小程序開(kāi)發(fā)公司服務(wù),打造樺南網(wǎng)絡(luò)公司原創(chuàng)品牌,更為您提供樺南網(wǎng)站排名全網(wǎng)營(yíng)銷(xiāo)落地服務(wù)。

如果你是使用軟件(如navicat、SQL yog等)來(lái)創(chuàng)建數(shù)據(jù)庫(kù)的話,先點(diǎn)一下軟件左邊的數(shù)據(jù)庫(kù)名稱(chēng),選中要?jiǎng)?chuàng)建的表所屬數(shù)據(jù)庫(kù),再新建表。

如果是使用命令行創(chuàng)建,則先執(zhí)行命令:use 數(shù)據(jù)庫(kù)名;(如在test數(shù)據(jù)庫(kù)中創(chuàng)建表,則輸入:use test;后按回車(chē))

如果mysql里面的數(shù)據(jù)過(guò)多,查詢(xún)太慢怎么辦?

問(wèn)題

我們有一個(gè) SQL,用于找到?jīng)]有主鍵 / 唯一鍵的表,但是在 MySQL 5.7 上運(yùn)行特別慢,怎么辦?

實(shí)驗(yàn)

我們搭建一個(gè) MySQL 5.7 的環(huán)境,此處省略搭建步驟。

寫(xiě)個(gè)簡(jiǎn)單的腳本,制造一批帶主鍵和不帶主鍵的表:

執(zhí)行一下腳本:

現(xiàn)在執(zhí)行以下 SQL 看看效果:

...

執(zhí)行了 16.80s,感覺(jué)是非常慢了。

現(xiàn)在用一下 DBA 三板斧,看看執(zhí)行計(jì)劃:

感覺(jué)有點(diǎn)慘,由于 information_schema.columns 是元數(shù)據(jù)表,沒(méi)有必要的統(tǒng)計(jì)信息。

那我們來(lái) show warnings 看看 MySQL 改寫(xiě)后的 SQL:

我們格式化一下 SQL:

可以看到 MySQL 將

select from A where A.x not in (select x from B) //非關(guān)聯(lián)子查詢(xún)

轉(zhuǎn)換成了

select from A where not exists (select 1 from B where B.x = a.x) //關(guān)聯(lián)子查詢(xún)

如果我們自己是 MySQL,在執(zhí)行非關(guān)聯(lián)子查詢(xún)時(shí),可以使用很簡(jiǎn)單的策略:

select from A where A.x not in (select x from B where ...) //非關(guān)聯(lián)子查詢(xún):1. 掃描 B 表中的所有記錄,找到滿足條件的記錄,存放在臨時(shí)表 C 中,建好索引2. 掃描 A 表中的記錄,與臨時(shí)表 C 中的記錄進(jìn)行比對(duì),直接在索引里比對(duì),

而關(guān)聯(lián)子查詢(xún)就需要循環(huán)迭代:

select from A where not exists (select 1 from B where B.x = a.x and ...) //關(guān)聯(lián)子查詢(xún)掃描 A 表的每一條記錄 rA: ? ? 掃描 B 表,找到其中的第一條滿足 rA 條件的記錄。

顯然,關(guān)聯(lián)子查詢(xún)的掃描成本會(huì)高于非關(guān)聯(lián)子查詢(xún)。

我們希望 MySQL 能先"緩存"子查詢(xún)的結(jié)果(緩存這一步叫物化,MATERIALIZATION),但MySQL 認(rèn)為不緩存更快,我們就需要給予 MySQL 一定指導(dǎo)。

...

可以看到執(zhí)行時(shí)間變成了 0.67s。

整理

我們?cè)\斷的關(guān)鍵點(diǎn)如下:

\1. 對(duì)于 information_schema 中的元數(shù)據(jù)表,執(zhí)行計(jì)劃不能提供有效信息。

\2. 通過(guò)查看 MySQL 改寫(xiě)后的 SQL,我們猜測(cè)了優(yōu)化器發(fā)生了誤判。

\3. 我們?cè)黾恿?hint,指導(dǎo) MySQL 正確進(jìn)行優(yōu)化判斷。

但目前我們的實(shí)驗(yàn)僅限于猜測(cè),猜中了萬(wàn)事大吉,猜不中就無(wú)法做出好的診斷。

mysql 一列長(zhǎng)度過(guò)大怎么處理

MySQL 數(shù)據(jù)庫(kù)的varchar類(lèi)型在4.1以下的版本中的最大長(zhǎng)度限制為255,其數(shù)據(jù)范圍可以是0~255或1~255(根據(jù)不同版本數(shù)據(jù)庫(kù)來(lái)定)。在 MySQL5.0以上的版本中,varchar數(shù)據(jù)類(lèi)型的長(zhǎng)度支持到了65535,也就是說(shuō)可以存放65532個(gè)字節(jié)的數(shù)據(jù),起始位和結(jié)束位占去了3個(gè)字 節(jié),也就是說(shuō),在4.1或以下版本中需要使用固定的TEXT或BLOB格式存放的數(shù)據(jù)可以使用可變長(zhǎng)的varchar來(lái)存放,這樣就能有效的減少數(shù)據(jù)庫(kù)文 件的大小。

MySQL 數(shù)據(jù)庫(kù)的varchar類(lèi)型在4.1以下的版本中,nvarchar(存儲(chǔ)的是Unicode數(shù)據(jù)類(lèi)型的字符)不管是一個(gè)字符還是一個(gè)漢字,都存為2個(gè)字節(jié) ,一般用作中文或者其他語(yǔ)言輸入,這樣不容易亂碼 ;varchar: 漢字是2個(gè)字節(jié),其他字符存為1個(gè)字節(jié) ,varchar適合輸入英文和數(shù)字。

4.0版本以下,varchar(20),指的是20字節(jié),如果存放UTF8漢字時(shí),只能存6個(gè)(每個(gè)漢字3字節(jié)) ;5.0版本以上,varchar(20),指的是20字符,無(wú)論存放的是數(shù)字、字母還是UTF8漢字(每個(gè)漢字3字節(jié)),都可以存放20個(gè),最大大小是65532字節(jié) ;varchar(20)在Mysql4中最大也不過(guò)是20個(gè)字節(jié),但是Mysql5根據(jù)編碼不同,存儲(chǔ)大小也不同,具體有以下規(guī)則:

a) 存儲(chǔ)限制

varchar 字段是將實(shí)際內(nèi)容單獨(dú)存儲(chǔ)在聚簇索引之外,內(nèi)容開(kāi)頭用1到2個(gè)字節(jié)表示實(shí)際長(zhǎng)度(長(zhǎng)度超過(guò)255時(shí)需要2個(gè)字節(jié)),因此最大長(zhǎng)度不能超過(guò)65535。

b) 編碼長(zhǎng)度限制

字符類(lèi)型若為gbk,每個(gè)字符最多占2個(gè)字節(jié),最大長(zhǎng)度不能超過(guò)32766;

字符類(lèi)型若為utf8,每個(gè)字符最多占3個(gè)字節(jié),最大長(zhǎng)度不能超過(guò)21845。

若定義的時(shí)候超過(guò)上述限制,則varchar字段會(huì)被強(qiáng)行轉(zhuǎn)為text類(lèi)型,并產(chǎn)生warning。

c) 行長(zhǎng)度限制

導(dǎo)致實(shí)際應(yīng)用中varchar長(zhǎng)度限制的是一個(gè)行定義的長(zhǎng)度。 MySQL要求一個(gè)行的定義長(zhǎng)度不能超過(guò)65535。若定義的表長(zhǎng)度超過(guò)這個(gè)值,則提示

ERROR 1118 (42000): Row size too large. The maximum row size for the used table type, not counting BLOBs, is 65535. You have to change some columns to TEXT or BLOBs。

當(dāng)前題目:mysql數(shù)據(jù)過(guò)長(zhǎng)怎么辦 mysql 字段太長(zhǎng)
網(wǎng)頁(yè)地址:http://www.rwnh.cn/article44/doohgee.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供做網(wǎng)站、面包屑導(dǎo)航網(wǎng)站設(shè)計(jì)、關(guān)鍵詞優(yōu)化、電子商務(wù)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

綿陽(yáng)服務(wù)器托管
汉中市| 福安市| 伊吾县| 兴城市| 同心县| 乌什县| 桂林市| 郑州市| 蛟河市| 慈利县| 景德镇市| 彭阳县| 竹山县| 鄂托克旗| 拉孜县| 靖安县| 汽车| 麻江县| 红河县| 乌兰察布市| 惠州市| 富平县| 古田县| 沂水县| 宁津县| 调兵山市| 文安县| 沾化县| 喀喇沁旗| 越西县| 保康县| 鱼台县| 镇赉县| 安新县| 仪陇县| 镶黄旗| 甘谷县| 太仆寺旗| 阳春市| 临武县| 达孜县|