demoMySQL(增团滥、刪、查报强、改惫撰、列表型、小數(shù)型躺涝、整型、浮點型扼雏、定點型)

Version:1.0StartHTML:000000201EndHTML:000031131StartFragment:000008929EndFragment:000031093StartSelection:000008929EndSelection:000031093SourceURL:http://www.reibang.com/p/32c1753eb3bd

desc:查看表結構

select *:查詢所有數(shù)據(jù)

交互方式

1坚嗜、客戶端連接認證:連接服務器、認證身份(mysql.exe -hPup)?

2诗充、客戶端發(fā)送SQL指令

3苍蔬、服務器接收SQL指令,并處理SQL指令蝴蜓,返回操作結果

4碟绑、客戶端接收結果俺猿,并顯示結果

5、斷開連接

MySQL服務器內部對象分成了四層:

系統(tǒng)(DBMS):管理數(shù)據(jù)庫的

數(shù)據(jù)庫(DB):放數(shù)據(jù)表的

數(shù)據(jù)表(Table):管理字段的

字段(Field) :存放數(shù)據(jù)的

將SQL的基本操作根據(jù)操作對象進行分類格仲,可分為三類: (庫操作押袍、表操作(包含字段操作) 、數(shù)據(jù)操作?)

庫操作?

新增數(shù)據(jù)庫:

? ? ? ? 1凯肋、create database 數(shù)據(jù)庫名字 [庫選項];

2谊惭、庫選項:用來約束數(shù)據(jù)庫,分為兩個選項:

1)字符集設定:charset/character set 具體字符集(數(shù)據(jù)存儲的編碼格式侮东,常用的有:GBK和UTF8

2)校對集設定:collate 具體校對集(數(shù)據(jù)比較的規(guī)則

? ? ? ? 3圈盔、數(shù)據(jù)庫名字不能用關鍵字(已經被系統(tǒng)使用的字符)或者保留字(將來系統(tǒng)可能會用到的字符)

創(chuàng)建結果:

????????在數(shù)據(jù)庫系統(tǒng)中,增加了對應的數(shù)據(jù)庫信息

會在保存數(shù)據(jù)的文件夾下(Data目錄)悄雅,創(chuàng)建一個對應數(shù)據(jù)庫名字的文件夾

????????每個數(shù)據(jù)庫下都有一個opt文件驱敲,保存了庫選項

表操作(包含字段操作)?

數(shù)據(jù)操作

注釋

--? 雙中劃線+空格:注釋(單行注釋),也可以使用#號

mysql.exe -h localhost -P 3306 -u root -p

-h:找到主機地址在哪

localhost:主機地址?

-P:端口(統(tǒng)一默認3306)

-u:用戶名(默認root)

-p:密碼

客戶端鏈接認證

mysql.exe -h localhost -P 3306 -u root -p

查看所有數(shù)據(jù)庫

show databases宽闲;

斷開連接

exit众眨、quit、\q

--? 雙中劃線+空格:注釋(單行注釋)便锨,也可以使用#號

-- 創(chuàng)建數(shù)據(jù)庫

create database mydb charset utf8;

表示該數(shù)據(jù)庫已存在围辙,要想繼續(xù)可另起名字或drop database `mydb`;

表示已刪除

-- 創(chuàng)建關鍵字數(shù)據(jù)庫

create database database charset utf8;-- 報錯

-- 使用反引號(非要使用關鍵字命名的數(shù)據(jù)庫加反引號)

create database `database` charset utf8;

--創(chuàng)建中文數(shù)據(jù)庫

create database 北京 charset utf8;

-- 如果報錯解決方案:告訴服務器當前中文的字符集是什么

右鍵命令行窗口——>屬性——>選項——>當前代碼頁(簡體中文GBK)

先執(zhí)行:set names gbk;

再執(zhí)行:create database?北京 charset utf8;

查看數(shù)據(jù)庫

? ? ? ?1、查看所有數(shù)據(jù)庫:show databases;

? ? ? ? 2放案、查看指定部分的數(shù)據(jù)庫(模糊查詢):show databases like 'pattern';

? ? ? ? ? ? ? ?1) pattern是匹配模式

? ? ? ? ? ? ? ? 2)%表示匹配多個字符

? ? ? ? ? ? ? ? 3)_表示匹配單個字符

3姚建、查看數(shù)據(jù)庫的創(chuàng)建語句:show create database 數(shù)據(jù)庫名字;

-- 查看所有數(shù)據(jù)庫

show databases;

-- 創(chuàng)建數(shù)據(jù)庫

create database informationtest charset utf8;

-- 以informationtion_開始的數(shù)據(jù)庫(_需要被轉義)

show databases like 'information_%';-- 相當于information%

show databases like 'information\_%';

-- 查看數(shù)據(jù)庫的創(chuàng)建語句

show create database mybd;

show create database?`database`; -- 關鍵字需要使用反引號

更新數(shù)據(jù)庫

????????????數(shù)據(jù)庫名字不可以修改

????????????數(shù)據(jù)庫的修改僅限庫選項,即字符集和校對集(校對集依賴字符集)

????????????alter database 數(shù)據(jù)庫名字 [庫選項];

????????????charset/character set [=] 字符集

????????????collate 校對集

刪除數(shù)據(jù)庫

drop database 數(shù)據(jù)庫名字;

-- 修改數(shù)據(jù)庫informationtest的字符集

alter database informationtest charset GBK;

注意:刪除數(shù)據(jù)庫有風險吱殉,需備份

-- 刪除數(shù)據(jù)庫:(drop database 數(shù)據(jù)庫名字;)

drop database informationtest;

表操作

--創(chuàng)建表

如何解決沒有數(shù)據(jù)庫選擇掸冤?

方案一:

顯式地指定表所屬的數(shù)據(jù)庫:

create table 數(shù)據(jù)庫名.表名();

create table if not exists mydb.student(-- 顯示地將student表放到mybd數(shù)據(jù)庫下

name varchar(10),

gender varchar(10),

number varchar(10),

age int

)charset utf8;

方案二:

隱式地指定表所屬數(shù)據(jù)庫

進入數(shù)據(jù)庫環(huán)境:use 數(shù)據(jù)庫名字;

--創(chuàng)建數(shù)據(jù)庫表

-- 進入數(shù)據(jù)庫

use mydb;

-- 創(chuàng)建表

create table class(

name varchar(10),

room varchar(10)

)charset utf8;

-- 查看所有表

show tables;

-- 查看以s結尾的表(盡量不用這種方式查,索引會失效友雳,效率會降低)

show tables like '%s';

-- 查看創(chuàng)建語句

show create table student;

show create table student\g -- \g等價于;

show create table student\G -- 將查到的結構旋轉90度變成縱向

-- 查看表結構

desc class;

describe class;

show columns from class;

-- 重命名表:student表—>my_student

rename table student to my_student;

-- 修改表選項:字符集

alter table?my_student charset = GBK;

字段操作

-- 給學生表增加ID稿湿,放到第一個位置

alter table?my_student add column id int first;

-- 將學生表中的number 學號字段變成固定長度,且放到第二位(id之后)

alter table my_student modify number char(10) after id;

-- 修改學生表中的gender字段為sex

alter table my_student change gender sex varchar(10);

注意:如果刪除字段押赊,這里的所有的都會清空饺藤,不可逆

-- 刪除學生表中的age年齡字段

alter table?my_student drop age;

表操作

-- 刪除數(shù)據(jù)表

drop table class;

數(shù)據(jù)操作

-- 方案一:插入數(shù)據(jù)

insert into?my_student?values (1, 'bc20200001', 'charry', 'female'), -- female:女生

(2, 'bc20200002', 'marry', 'male'); -- male:男生

-- 方案二:插入數(shù)據(jù):指定字段列表

insert into?my_student (id,number,name,sex) values

(3, 'bc20200003', 'harry', 'female'),

(4, 'bc20200004', 'karry', 'male');

數(shù)據(jù)操作

-- 查看所有數(shù)據(jù)

select * from my_student;

-- 查看指定字段、指定條件的數(shù)據(jù)

select id,number,sex,name from my_student

where id=1;-- 查看滿足id為1的學生的信息

-- 更新數(shù)據(jù)(如果不寫where name='karry'會導致“普天同慶”流礁,全部改變)

update?my_student set sex='female' where name='karry';

注意:不可逆的涕俗,謹慎刪除

-- 刪除數(shù)據(jù)

delete from?my_student where sex='male';

delete from?my_student where name='charry';

MYSQL數(shù)據(jù)類型(列類型)

-- 創(chuàng)建整型表

create table my_int(

int_1 tinyint,

int_2 smallint,

int_3 int,

int_4 bigint

)charset utf8;

-- 插入數(shù)據(jù)

insert into my_int

values(100,100,100,100);? ? -- 有效數(shù)據(jù)

insert into my_int

values('a','b','199','f');? ? -- 無效數(shù)據(jù):類型限定

insert into my_int

values(255,10000,100000,1000000);? ? -- 錯誤:超出范圍

-- 給表增加一個無符號類型

alter table my_int add int_5 tinyint unsigned; -- unsigned:無符號類型

-- 插入數(shù)據(jù)

insert into my_int

values(127,10000,100000,1000000,255);

-- 指定顯示寬度為1

alter table my_int add int_6 tinyint(1) unsigned;

-- 插入數(shù)據(jù)

insert into my_int

values(127,0,0,0,255,255);

-- 顯示寬度為2,? ? 0填充(導致數(shù)字自動變?yōu)闊o符號)

alter table my_int add int_7 tinyint(2) zerofill;

-- 插入數(shù)據(jù)

insert into my_int

values(1,1,1,1,1,1,1);

insert into my_int

values(100,100,100,100,100,100,100);

M:代表總長度D:代表小數(shù)部分長度

整數(shù)部分的長度 = M - D

-- 浮點數(shù)表

create table my_float(

f1 float,

f2 float(10,2), -- 10位在精度范圍之外

f3 float(6,2) -- 6位在精度范圍之內

)charset utf8;

-- 插入數(shù)據(jù)

insert into my_float

values(1000.10,1000.10,1000.10);

insert into my_float

values(1234567890,12345678.90,1234.56);

insert into my_float

values(3e38,3.01e7,1234.56);

insert into my_float

values(9999999999,99999999.99,9999.99); -- 后兩個是最大值

-- 超出長度插入數(shù)據(jù)

insert into my_float

values(123456,1234.12345678,123.9876543); -- 小數(shù)部分可以超出長度

insert into my_float

values(123456,1234.12,12345.56); -- 最后一個整數(shù)部分超出

-- 創(chuàng)建定點數(shù)表

create table my_decimal(

f1 float(10,2),

d1 decimal(10,2)

)charset utf8;

-- 插入數(shù)據(jù)

insert into my_decimal

values(12345678.90,12345678.90); -- 有效數(shù)據(jù)

insert into my_decimal

values(1234.123456,1234.123456); -- 小數(shù)部分可以超出長度

-- 查看警告

show warnings;

-- 插入數(shù)據(jù)

insert into my_decimal

values(99999999.99,99999999.99); -- 沒有問題

insert into my_decimal

values(99999999.99,99999999.999); -- 進位超出范圍

?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市神帅,隨后出現(xiàn)的幾起案子再姑,更是在濱河造成了極大的恐慌,老刑警劉巖找御,帶你破解...
    沈念sama閱讀 221,576評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件元镀,死亡現(xiàn)場離奇詭異绍填,居然都是意外死亡,警方通過查閱死者的電腦和手機栖疑,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,515評論 3 399
  • 文/潘曉璐 我一進店門讨永,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人蔽挠,你說我怎么就攤上這事住闯。” “怎么了澳淑?”我有些...
    開封第一講書人閱讀 168,017評論 0 360
  • 文/不壞的土叔 我叫張陵比原,是天一觀的道長。 經常有香客問我杠巡,道長量窘,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,626評論 1 296
  • 正文 為了忘掉前任氢拥,我火速辦了婚禮蚌铜,結果婚禮上,老公的妹妹穿的比我還像新娘嫩海。我一直安慰自己冬殃,他們只是感情好,可當我...
    茶點故事閱讀 68,625評論 6 397
  • 文/花漫 我一把揭開白布叁怪。 她就那樣靜靜地躺著审葬,像睡著了一般。 火紅的嫁衣襯著肌膚如雪奕谭。 梳的紋絲不亂的頭發(fā)上涣觉,一...
    開封第一講書人閱讀 52,255評論 1 308
  • 那天,我揣著相機與錄音血柳,去河邊找鬼官册。 笑死,一個胖子當著我的面吹牛难捌,可吹牛的內容都是我干的膝宁。 我是一名探鬼主播,決...
    沈念sama閱讀 40,825評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼根吁,長吁一口氣:“原來是場噩夢啊……” “哼昆汹!你這毒婦竟也來了?” 一聲冷哼從身側響起婴栽,我...
    開封第一講書人閱讀 39,729評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎辈末,沒想到半個月后愚争,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體映皆,經...
    沈念sama閱讀 46,271評論 1 320
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 38,363評論 3 340
  • 正文 我和宋清朗相戀三年轰枝,在試婚紗的時候發(fā)現(xiàn)自己被綠了捅彻。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,498評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡鞍陨,死狀恐怖步淹,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情诚撵,我是刑警寧澤缭裆,帶...
    沈念sama閱讀 36,183評論 5 350
  • 正文 年R本政府宣布,位于F島的核電站寿烟,受9級特大地震影響澈驼,放射性物質發(fā)生泄漏。R本人自食惡果不足惜筛武,卻給世界環(huán)境...
    茶點故事閱讀 41,867評論 3 333
  • 文/蒙蒙 一缝其、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧徘六,春花似錦内边、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,338評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至炉擅,卻和暖如春辉懒,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背谍失。 一陣腳步聲響...
    開封第一講書人閱讀 33,458評論 1 272
  • 我被黑心中介騙來泰國打工眶俩, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人快鱼。 一個月前我還...
    沈念sama閱讀 48,906評論 3 376
  • 正文 我出身青樓颠印,卻偏偏與公主長得像,于是被迫代替她去往敵國和親抹竹。 傳聞我的和親對象是個殘疾皇子线罕,可洞房花燭夜當晚...
    茶點故事閱讀 45,507評論 2 359

推薦閱讀更多精彩內容