如果是修改表字段 alter table table_name column column_name new_name;
成都創(chuàng)新互聯(lián)公司主營(yíng)槐蔭網(wǎng)站建設(shè)的網(wǎng)絡(luò)公司,主營(yíng)網(wǎng)站建設(shè)方案,重慶APP開(kāi)發(fā)公司,槐蔭h5重慶小程序開(kāi)發(fā)搭建,槐蔭網(wǎng)站營(yíng)銷(xiāo)推廣歡迎槐蔭等地區(qū)企業(yè)咨詢(xún)
修改字段的數(shù)據(jù)?
update table_name set xx=yy where ...;不用where 就是全改成一樣
一、修改表
二、復(fù)制表
三、表字段的數(shù)據(jù)類(lèi)型
存儲(chǔ)引擎決定了表的類(lèi)型,而表內(nèi)存放的數(shù)據(jù)也要有不同的類(lèi)型,每種數(shù)據(jù)類(lèi)型都有自己的寬度,但寬度是可選的。
mysql常用數(shù)據(jù)類(lèi)型有:
數(shù)值類(lèi)型
1、整數(shù)類(lèi)型
TINYINT SMALLINT MEDIUMINT INT BIGINT
作用:存儲(chǔ)年齡,等級(jí),id,各種號(hào)碼等
注意:為該類(lèi)型指定寬度時(shí),僅僅只是指定查詢(xún)結(jié)果的顯示寬度,與存儲(chǔ)范圍無(wú)關(guān),存儲(chǔ)范圍如下
其實(shí)我們完全沒(méi)必要為整數(shù)類(lèi)型指定顯示寬度,使用默認(rèn)的就可以了
默認(rèn)的顯示寬度,都是在最大值的基礎(chǔ)上加1
2、浮點(diǎn)型
定點(diǎn)數(shù)類(lèi)型 DEC等同于DECIMAL
浮點(diǎn)類(lèi)型:FLOAT DOUBLE
作用:存儲(chǔ)薪資、身高、體重、體質(zhì)參數(shù)等
3、日期類(lèi)型
DATE TIME DATETIME TIMESTAMP YEAR
作用:存儲(chǔ)用戶(hù)注冊(cè)時(shí)間,文章發(fā)布時(shí)間,員工入職時(shí)間,出生時(shí)間,過(guò)期時(shí)間等
datatime與timestamp的區(qū)別
4、字符串類(lèi)型
總結(jié):
單從數(shù)據(jù)類(lèi)型的實(shí)現(xiàn)機(jī)制去考慮,char數(shù)據(jù)類(lèi)型的處理速度更快,有時(shí)甚至可以超出varchar處理速度的50%。
但對(duì)于InnoDB數(shù)據(jù)表,內(nèi)部的行存儲(chǔ)格式?jīng)]有區(qū)分固定長(zhǎng)度和可變長(zhǎng)度列(所有數(shù)據(jù)行都使用指向數(shù)據(jù)列值的頭指針),因此在本質(zhì)上,使用固定長(zhǎng)度的CHAR列不一定比使用可變長(zhǎng)度VARCHAR列性能要好。因而,主要的性能因素是數(shù)據(jù)行使用的存儲(chǔ)總量。由于CHAR平均占用的空間多于VARCHAR,因此使用VARCHAR來(lái)最小化需要處理的數(shù)據(jù)行的存儲(chǔ)總量和磁盤(pán)I/O是比較好的。
5、枚舉類(lèi)型和集合類(lèi)型
字段的值只能在給定范圍中選擇,如單選框,多選框
enum 單選 只能在給定的范圍內(nèi)選一個(gè)值,如性別 sex 男male/女female
set 多選 在給定的范圍內(nèi)可以選擇一個(gè)或一個(gè)以上的值(愛(ài)好1,愛(ài)好2,愛(ài)好3...)
你好
修改表的數(shù)據(jù)一般使用update語(yǔ)句
具體的話(huà)參考相關(guān)SQL文檔吧
不是幾句話(huà)能說(shuō)明白的
祝你好運(yùn)
望采納
本期我們用 MySQL 提供的 DBUG 工具來(lái)研究 MySQL 的 SQL 處理流程。
起手先造個(gè)實(shí)例
這里得稍微改一下實(shí)例的啟動(dòng)文件 start,將 CUSTOM_MYSQLD 改為 mysqld-debug:
重啟一下實(shí)例,加上 debug 參數(shù):
我們來(lái)做一兩個(gè)實(shí)驗(yàn),說(shuō)明 DBUG 包的作用:
先設(shè)置一個(gè)簡(jiǎn)單的調(diào)試規(guī)則,我們?cè)O(shè)置了兩個(gè)調(diào)試選項(xiàng):
d:開(kāi)啟各個(gè)調(diào)試點(diǎn)的輸出
O,/tmp/mysqld.trace:將調(diào)試結(jié)果輸出到指定文件
請(qǐng)點(diǎn)擊輸入圖片描述
然后我們創(chuàng)建了一張表,來(lái)看一下調(diào)試的輸出結(jié)果:
請(qǐng)點(diǎn)擊輸入圖片描述
可以看到 create table 的過(guò)程中,MySQL 的一些細(xì)節(jié)操作,比如分配內(nèi)存 alloc_root 等
這樣看還不夠直觀(guān),我們?cè)黾右恍┬畔ⅲ?/p>
請(qǐng)點(diǎn)擊輸入圖片描述
來(lái)看看效果:
請(qǐng)點(diǎn)擊輸入圖片描述
可以看到輸出變成了調(diào)用樹(shù)的形式,現(xiàn)在就可以分辨出 alloc_root 分配的內(nèi)存,是為了解析 SQL 時(shí)用的(mysql_parse)
我們?cè)僭黾右恍┯杏玫男畔ⅲ?/p>
請(qǐng)點(diǎn)擊輸入圖片描述
可以看到結(jié)果中增加了文件名和行號(hào):
請(qǐng)點(diǎn)擊輸入圖片描述
現(xiàn)在我們可以在輸出中找一下統(tǒng)計(jì)表相關(guān)的信息:
請(qǐng)點(diǎn)擊輸入圖片描述
可以看到 MySQL 在這里非常機(jī)智,直接執(zhí)行了一個(gè)內(nèi)置的存儲(chǔ)過(guò)程來(lái)更新統(tǒng)計(jì)表。
沿著 que_eval_sql,可以找到其他類(lèi)似的統(tǒng)計(jì)表,比如下面這些:
請(qǐng)點(diǎn)擊輸入圖片描述
請(qǐng)點(diǎn)擊輸入圖片描述
本次實(shí)驗(yàn)中,我們借助了 MySQL 的 DBUG 包,來(lái)讓 MySQL 將處理過(guò)程暴露出來(lái)。MySQL 中類(lèi)似的技術(shù)還有不少,比如 performance_schema,OPTIMIZER_TRACE 等等。
這些技術(shù)將 MySQL 的不同方向的信息暴露出來(lái),方便大家理解其中機(jī)制。
使用update:
update 表名 set 字段1='修改值1',字段2='修改值2',字段5='修改值5' where 字段='某些值';
該語(yǔ)句是將表中所要求字段匹配后的行,進(jìn)行相應(yīng)字段的修改。
例如,表person
id/name/age
1/a/15
2/b/15
3/c/16
update person set name=d where age=16;
結(jié)果為3/c/16被修改為3/d/16。