mysql學(xué)習(xí)

一哥谷、 建表Tables
column: 列名稱
dateType:這一列的類型(int整數(shù)類型、varchar字符串類型 varchar(20)值的最大長度是20瓶堕、longtext可以存儲很大數(shù)據(jù)隘道,最多可存儲4G大小、bigint用來存儲更大數(shù)據(jù)的整數(shù)類型)
pk主鍵:這一列的值不能重復(fù)(主鍵的意思就是保證不能重復(fù))如何保證不能重復(fù)呢郎笆?
AI自動增加:設(shè)置為Y
nn不為空:這一列的值是不是允許為空(Y是不允許為空)
Default: 默認值

修改表:圖形界面表名右鍵選擇Alter Table

二谭梗、操作表(增刪改查)

1.想要操作數(shù)據(jù)庫,首先先use這個數(shù)據(jù)庫宛蚓,然后執(zhí)行這個語句

use 數(shù)據(jù)庫名;

2.顯示所有數(shù)據(jù)庫的表

show tables;

注釋的寫法 --

-- show tables;

3.給users表增加數(shù)據(jù) insert into 表名 (列名) values (數(shù)據(jù));

insert into users (username, `password`, realname) values ('zhangsan','123','張三');
  • 批量插入:
insert into test_table (name, age, sex) values ('張三', 18, '男'), ('李四',16,'女'), ('王五',19,'女')
  1. 查詢
  • 查詢?nèi)?/li>
select * from users;

出于性能考慮激捏,一般情況下,避免使用*

  • 查詢部分select 列名 from 表
select id, username from users;
  • 加查詢條件 (后面加 where 條件)
select * from users where username='zhangsan';
  • 多個查詢條件(where 條件1 and 條件2)
    (where 條件1or條件2)
select * from users where username='zhangsan' and `password`='123';
  • 模糊查詢 like
select * from users where username like '%zhang%';
  • 排序 order by默認正序凄吏,加desc后是倒序
select * from users where password like '%1%' order by id desc;
  1. 更新 update 表名 setwhere 條件
update users set realname='李四' where username='lisi';

若執(zhí)行update報錯远舅,則需執(zhí)行下面的語句闰蛔,執(zhí)行完刪除,重新執(zhí)行剛才的update語句

SET SQL_SAFE_UPDATES = 0;

6.刪除 delete from 表名 where 條件
一般刪除是軟刪除图柏,不會直接使用delete序六,而是使用update

  • 比如加一列state狀態(tài),是1的話存在爆办,0的話刪除
update users set state='0' where username='lisi';
select * from users where state='1';
  • 如果想要查詢state不等于0难咕,使用<>
select * from users where state <> '0';

三课梳、nodejs連接數(shù)據(jù)庫

  1. 下載mysql包
npm i mysql -S
  1. 引用
const mysql = require('mysql')

3.配置并連接數(shù)據(jù)庫

// 創(chuàng)建鏈接對象
const con = mysql.createConnection({
  // 配置
})
// 開始連接
con.connect()

4.執(zhí)行sql

const sql = `select * from users`;
con.query(sql, (err, result) => {
  if (err) {
    return
  }
  console.log(result)
})

四距辆、工作中遇到的一些sql 關(guān)鍵字的意思:

as 作為(列或表的)別名(可省略)

Coalesce(A,B)相當(dāng)于三目表達式,如果A不為null返回A暮刃,否則如果B不為null返回B跨算,否則返回null

distinct去重

in查詢滿足指定范圍內(nèi)的數(shù)據(jù)

select column1, column2 from table where column1 in (value1, value2, value3)

between .... and ...:查詢某個范圍內(nèi)的值

select * from table where column between value1 and value2

to_char(A, B)把A轉(zhuǎn)成B格式的字符串

inner join ...on...

根據(jù)on的條件將兩個表鏈接起來,當(dāng)兩表同時滿足鏈接的條件椭懊,滿足的部分才會列出

left join返回左表的全部行和右表滿足on條件的行

// Table A是左邊的表诸蚕,Table B是右邊的表
select * from Table A left join Table B
on Table A.id=Table B.id

right join返回右表的全部行和左表滿足on條件的行

// Table A是左邊的表,Table B是右邊的表
select * from Table A right join Table B
on Table A.id=Table B.id

不等于 <> 或者!=

like +通配符字符串:模糊查詢

mysql通配符有兩個:

%:表示0個或多個字符(任意個字符)

_ : 表示一個字符

order by 子句進行排序 氧猬,默認是升序

order by 字段名 asc(升序

order by 字段名 desc(降序

組合排序:就是先按第一個字段進行排序背犯,如果第一個字段相同,才按第二個字段進行排序盅抚,依次類推

select * from 表名 where 字段= 值 order by  字段名1 asc漠魏,字段名2 desc;

聚合函數(shù)

之前所做的查詢都是橫向查詢妄均,它們都是根據(jù)條件一行一行進行判斷柱锹。而使用聚合函數(shù)查詢是縱向查詢,它是對一列的值進行計算丰包,然后返回一個結(jié)果值禁熏。另外聚合函數(shù)會忽略空值

五個聚合函數(shù):count sum max min avg

聚合函數(shù)寫在select后字段名的地方:

Select 字段名 from 表名

Select count(age) from 表名;

// 統(tǒng)計所有數(shù)據(jù)個數(shù):
select count(*) from 表名邑彪;

分組查詢

使用group by語句對查詢信息進行分組瞧毙,將分組字段結(jié)果中相同內(nèi)容作為一組;

Select 字段1寄症,字段2 from 表名 group by 分組字段 having 條件升筏;

Select * from 表名 group by sex;
  • 這句話會將sex相同的數(shù)據(jù)作為一組,但是會返回每組的第一條瘸爽,沒有任何意義您访;

  • 分組的目的就是為了統(tǒng)計,一般分組查詢會跟聚合函數(shù)一起搭配使用剪决;

  • 分組后聚合函數(shù)不是操作所有數(shù)據(jù)灵汪,而是操作一組數(shù)據(jù)檀训。

select sum(score), sex from 表名 group by sex;

注意:當(dāng)我們使用某個字段分組,在查詢的時候也需要將這個字段查詢出來享言,否則看不到數(shù)據(jù)屬于哪個組的

where是分組前的條件峻凫,分組后的過濾條件使用having;

Select count(*), sex from hero where age < 30 group by sex having count(*) > 2;

having和where的區(qū)別:

  • having在分組后對數(shù)據(jù)進行過濾
  • where是在分組前對數(shù)據(jù)進行過濾
  • having后面可以使用聚合函數(shù)
  • where后面不可以使用聚合函數(shù)

limit:限制查詢記錄的條數(shù) limit offset, length 或者 limit length(只適用第一頁);

offset指的是偏移量,可以認為是跳過的記錄數(shù)量览露,默認為0

length是指需要顯示的總記錄數(shù)

 select 字段列表 [as 別名] from 表名 [where子句] [group by子句] [having子句] [order by子句] [limit子句];

case when ... then ... else ... End
case when 條件A then A when條件B then B when條件C then C else D end相當(dāng)于if else語句

select name,  (case when score < 60 then 'fail' when score >=60 and score < 80 then 'pass' else 'fine' end) as grade from table

sql中除了數(shù)值類型荧琼,其他字段類型的值必須使用引號引起,建議單引號
desc 表名:查看表結(jié)構(gòu)
子查詢就是在主select 里面套select from, 相當(dāng)于從一個結(jié)果集里面去查詢差牛。子查詢一般都寫在括號里面命锄,然后在括號外面用as接收這個子查詢出來的值

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市偏化,隨后出現(xiàn)的幾起案子脐恩,更是在濱河造成了極大的恐慌,老刑警劉巖侦讨,帶你破解...
    沈念sama閱讀 217,406評論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件驶冒,死亡現(xiàn)場離奇詭異,居然都是意外死亡韵卤,警方通過查閱死者的電腦和手機骗污,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,732評論 3 393
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來沈条,“玉大人需忿,你說我怎么就攤上這事∨睦穑” “怎么了贴谎?”我有些...
    開封第一講書人閱讀 163,711評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長季稳。 經(jīng)常有香客問我擅这,道長,這世上最難降的妖魔是什么景鼠? 我笑而不...
    開封第一講書人閱讀 58,380評論 1 293
  • 正文 為了忘掉前任仲翎,我火速辦了婚禮,結(jié)果婚禮上铛漓,老公的妹妹穿的比我還像新娘溯香。我一直安慰自己,他們只是感情好浓恶,可當(dāng)我...
    茶點故事閱讀 67,432評論 6 392
  • 文/花漫 我一把揭開白布玫坛。 她就那樣靜靜地躺著,像睡著了一般包晰。 火紅的嫁衣襯著肌膚如雪湿镀。 梳的紋絲不亂的頭發(fā)上炕吸,一...
    開封第一講書人閱讀 51,301評論 1 301
  • 那天,我揣著相機與錄音勉痴,去河邊找鬼赫模。 笑死,一個胖子當(dāng)著我的面吹牛蒸矛,可吹牛的內(nèi)容都是我干的瀑罗。 我是一名探鬼主播,決...
    沈念sama閱讀 40,145評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼雏掠,長吁一口氣:“原來是場噩夢啊……” “哼斩祭!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起磁玉,我...
    開封第一講書人閱讀 39,008評論 0 276
  • 序言:老撾萬榮一對情侶失蹤停忿,失蹤者是張志新(化名)和其女友劉穎驾讲,沒想到半個月后蚊伞,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,443評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡吮铭,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,649評論 3 334
  • 正文 我和宋清朗相戀三年时迫,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片谓晌。...
    茶點故事閱讀 39,795評論 1 347
  • 序言:一個原本活蹦亂跳的男人離奇死亡掠拳,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出纸肉,到底是詐尸還是另有隱情溺欧,我是刑警寧澤,帶...
    沈念sama閱讀 35,501評論 5 345
  • 正文 年R本政府宣布柏肪,位于F島的核電站姐刁,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏烦味。R本人自食惡果不足惜聂使,卻給世界環(huán)境...
    茶點故事閱讀 41,119評論 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望谬俄。 院中可真熱鬧柏靶,春花似錦、人聲如沸溃论。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,731評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽钥勋。三九已至炬转,卻和暖如春控汉,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背返吻。 一陣腳步聲響...
    開封第一講書人閱讀 32,865評論 1 269
  • 我被黑心中介騙來泰國打工姑子, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人测僵。 一個月前我還...
    沈念sama閱讀 47,899評論 2 370
  • 正文 我出身青樓街佑,卻偏偏與公主長得像,于是被迫代替她去往敵國和親捍靠。 傳聞我的和親對象是個殘疾皇子沐旨,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,724評論 2 354

推薦閱讀更多精彩內(nèi)容