溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

mysql數(shù)據(jù)庫基本操作(表結(jié)構(gòu))

發(fā)布時間:2020-06-15 20:07:32 來源:網(wǎng)絡(luò) 閱讀:695 作者:劉真圓 欄目:MySQL數(shù)據(jù)庫

裝包啟服務(wù)后會自動生成相關(guān)的配置文件

首次運(yùn)行時會自動生成 root 初始秘密
初始密碼在服務(wù)日志文件中查找 grep -i password /var/log/mysql.log

進(jìn)去mysql

mysql -hlocalhost -uroot -p初始密碼

set global validate_password_policy=0;
#修改密碼默認(rèn)等級為0
#0為長度 , 1為字母長度符號,2為字母長度符號,字典文件

set global validate_password_length=6;
#修改密碼默認(rèn)長度要求為6

alter user root@"localhost" identified by '123456';
#修改密碼

命令行指令為臨時有效,將命令寫入配置文件/etc/my.cnf永久生效
寫入完成后重啟服務(wù)即可生效

################################################################
名詞解釋
DB,DataBase
數(shù)據(jù)庫,依照某種數(shù)據(jù)模型進(jìn)行組織并存放到存儲器的數(shù)據(jù)集合
DBMS,DataBase Management System
數(shù)據(jù)庫管理系統(tǒng),用來操作和管理數(shù)據(jù)庫的大型服務(wù)器軟件
DBS, DataBase System
帶有數(shù)據(jù)庫,數(shù)據(jù)庫管理系統(tǒng)的服務(wù)器

##################################################################

sql命令的分類

DDL 數(shù)據(jù)定義語言
(create alter drop)
DML 數(shù)據(jù)操作語言
(insert update delete)
DCL 數(shù)據(jù)控制語言
(grant revoke)
DTL 數(shù)據(jù)事物語言
(commit rollback savepoint)

###################################################################
2創(chuàng)建庫
create database 庫名;
#創(chuàng)建庫
show databases;
#查看已有庫
drop database 庫名;
#刪除庫
select database();
#查看當(dāng)前所在的庫
use 庫名;
#進(jìn)入庫

##################################################################
建表
create table 庫名.表名(
字段名 類型(寬度) 約束條件,
字段名 類型(寬度) 約束條件,
...
...
);
create table gamedb.stu(
name char(10), #字符(10)個
age int #數(shù)值
);
insert into 庫名.表名 values(值列表);
#插入表記錄
select * from 庫名.表名;
#查看表記錄
delete from 庫名.表名;
#刪除表記錄
desc 庫名.表名;
#查看表結(jié)構(gòu)
drop table 庫名.表名;
#刪除表

##################################################################
mysql數(shù)據(jù)類型
數(shù)值型:×××、浮點(diǎn)型
整型:根據(jù)存儲數(shù)值的范圍整型類型的又分為:
類型 tinyint smallintmediumintintbigint
用途 微小 小 中 大 特大

大小 1字節(jié) 2字節(jié) 3字節(jié) 4字節(jié) 8字節(jié)

分為有符號無符號,范圍分別為:

有符號 -128~27 -32768~2767 -2^23~2^23-1 -2^31~2^31-1 -2^63~2^63-1

無符號 0~255 0~65535 0~2^24-1 0~2^32-1 0~2^64-1

創(chuàng)建時使用 unsigned 修飾時,對應(yīng)的字段只保存正數(shù)

寬度僅是顯示寬度,存儲數(shù)值的大小由類型決定

使用 zerofill 時,填0代替空格補(bǔ)位

#例如: age int(3)

 insert in to a values(3)

 數(shù)據(jù)庫顯示為 003

數(shù)值超出范圍時,報錯

浮點(diǎn)型:根據(jù)存儲的范圍分為單精度和雙精度:
單精度 float(n,m)4字節(jié)
雙精度 double(n,m)8字節(jié)

#n表示總位數(shù),m表示小數(shù)位的位數(shù)

#例如:float(5,2) 最大為999.99最小為-999.99

數(shù)值類型的寬度是顯示寬度不能夠限制給字段的賦值的大小,大小由字段類型決定。

################################################################

字符型:

定長: char(字符數(shù))

#最大長度255字符,不夠指定字符數(shù)時在右邊用空格補(bǔ)齊,字符數(shù)斷超出時,無法寫入數(shù)據(jù)。

變長:varchar

#按數(shù)據(jù)實際大小分配存儲空間,字符數(shù)斷超出時,無法寫入數(shù)據(jù)。

大文本類型:text/blob

#字符數(shù)大于65535存儲時使用。

實際生產(chǎn)環(huán)境中使用 char 的會相對較多,因為 varchar 會占用一部分CPU資源來計算存儲大小。

日期時間型
年 year YYYY 2017

#year默認(rèn)用4為數(shù)字表示,當(dāng)只用2位數(shù)字賦值時,01~69視為2000~2069

70~99時為1970~1999

日期 date YYYYMMDD20171220
時間 time HHMMSS155145
日期時間
datetime YYYYMMDDHHMMSS
timestamp YYYYMMDDHHMMSS
datetime 當(dāng)沒有為他賦值時,會顯示為空
timestamp 當(dāng)沒有為他賦值時,會使用系統(tǒng)當(dāng)前時間

###################################################################
now()
#當(dāng)前系統(tǒng)的時間
year()
#獲取數(shù)據(jù)中的年
day()
#獲取數(shù)據(jù)中的天
date()
#獲取數(shù)據(jù)中的日期
time()
#獲取數(shù)據(jù)中的時間

###################################################################
枚舉類型:字段的值只能在列舉的范圍內(nèi)選擇
字段名 enum(值列表)
#單選,從給定值集合中選擇單個值。
字段名 set(值列表)
#多選,從給定值集合中選擇一個或多個值。

###################################################################
設(shè)置字段的約束條件:作用限制如何給字段賦值。
Null 是否允許為空 不允許則在類型后面跟NOT Null
Default 設(shè)置默認(rèn)值,缺省為NULL 類型后面跟default

###################################################################
修改表結(jié)構(gòu)
mysql> alter table 表名 執(zhí)行動作;

add 字段名 類型(寬度) 約束條件,
#添加新字段,默認(rèn)在最后。
add 字段名 類型(寬度) 約束條件 first;
#所有字段的前面
add 字段名 類型(寬度) 約束條件 after 字段名;
#在什么字段后面添加
drop 字段名;
#刪除字段
modify 字段 類型(寬度) 約束條件
#修改字段類型
change 原字段名 新字段名 類型(寬度) 約束條件
#修改字段名
alter table 原表名 rename 新表名;
#修改表名

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI