久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 4481|回復: 0
收起左側

mysql寫新數據時某列值總是被自動修改

[復制鏈接]
ID:110653 發表于 2016-4-7 23:13 來自觸屏版 | 顯示全部樓層 |閱讀模式
0、導讀

往表里寫入新數據時,卻一直報告主鍵沖突,某列值一直被重置為一個固定值,疑似被黑,啥情況?

1、問題描述

某朋友的線上數據庫,懷疑被侵入了。具體表象是:INSERT的時候,某列值總被自動改成一個固定值。

他們先自查了 TRIGGER 和 EVENT,都是空的,確定不是因為這兩種原因引起,實在想不出是哪里被動了手腳。

問題的現象:

MariaDB [information_schema]> use bbs9;
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -A
Database changed

MariaDB [bbs9]> INSERT INTO cdb_mythreads_latest (uid,username,tid,fid,subject,special,dateline) VALUES ('1239009','yayv','13482713','815','bbs5 ................','0','1459569279');

ERROR 1062 (23000): Duplicate entry '1239009-8388607' for key 'PRIMARY'

可以看到,tid列的值被從 13482713(原始值) 自動替換成了 8388607(篡改值)。

更讓人奇怪的是,這條SQL在mysql client端手動執行手,也會報告同樣的錯誤。究竟是什么黑客這么牛逼呢,百思不得其解~~~

2、原因分析

單從現象來看,好像還真是被黑了的意思。

but,但是,可是,你如果足夠細心,就會發現端倪。

為什么這么說呢,因為 8388607 這個數值是不是看起來挺眼熟的?嗯,沒錯,你才對了,這個值是 MEDIUMINT 類型的最大值,而 MEDIUMINT UNSIGNED 的最大值是 16777215。

當然了,你再認真看一眼表的名字是什么:cdb_mythreads_latest,我又要呵呵了,你懂得的。

3、其他建議

既然原因已經清楚了,那么解決起來也就簡單了,只需要把tid列類型改成INT UNSIGNED,甚至BIGINT UNSIGNED都行。

MEDIUMINT和INT兩種類型,也只是差了1個字節,何必呢。與其在這個地方節約1個字節,還不如在別的CHAR/VARCHAR/TEXT列調整下,其優化效果要好的多得多。

4、相關案例
回復

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規則

小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術交流QQ群281945664

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 久久专区 | 欧美日韩视频在线播放 | 久久综合一区二区 | 国产98色在线 | 日韩 | 黄色一级片aaa | 国产精品一区二区在线 | 天天澡天天狠天天天做 | 欧美日韩国产中文 | 中文字幕乱码亚洲精品一区 | 精品中文字幕一区二区三区 | 国产高清精品一区二区三区 | 午夜影晥 | 91久久视频 | 综合久久久久 | 国产四区| 91在线视频免费观看 | 国产综合在线视频 | 亚洲精品视频在线播放 | 亚洲国产伊人 | 精品免费视频一区二区 | 婷婷久久五月 | 国产又爽又黄的视频 | 国产日韩精品一区 | 一区二区三区av | 亚洲视频免费在线观看 | 超碰97人人人人人蜜桃 | 蜜桃综合在线 | 国产精品欧美一区喷水 | 本道综合精品 | 日本一道本 | 盗摄精品av一区二区三区 | 色爱综合 | 欧一区| 荷兰欧美一级毛片 | 久久久久久综合 | 亚洲国产成人精品女人久久久 | 成人日韩精品 | 国产精品高潮呻吟久久 | 精品国产乱码久久久久久88av | av在线播放免费 | 国产高清在线观看 |