mysql學習

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

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

二、操作表(增刪改查)

1.想要操作數據庫,首先先use這個數據庫,然后執行這個語句

use 數據庫名;

2.顯示所有數據庫的表

show tables;

注釋的寫法 --

-- show tables;

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

insert into users (username, `password`, realname) values ('zhangsan','123','張三');
  • 批量插入:
insert into test_table (name, age, sex) values ('張三', 18, '男'), ('李四',16,'女'), ('王五',19,'女')
  1. 查詢
  • 查詢全部
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';

若執行update報錯,則需執行下面的語句,執行完刪除,重新執行剛才的update語句

SET SQL_SAFE_UPDATES = 0;

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

  • 比如加一列state狀態,是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連接數據庫

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

3.配置并連接數據庫

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

4.執行sql

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

四、工作中遇到的一些sql 關鍵字的意思:

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

Coalesce(A,B)相當于三目表達式,如果A不為null返回A,否則如果B不為null返回B,否則返回null

distinct去重

in查詢滿足指定范圍內的數據

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

between .... and ...:查詢某個范圍內的值

select * from table where column between value1 and value2

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

inner join ...on...

根據on的條件將兩個表鏈接起來,當兩表同時滿足鏈接的條件,滿足的部分才會列出

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;

聚合函數

之前所做的查詢都是橫向查詢,它們都是根據條件一行一行進行判斷。而使用聚合函數查詢是縱向查詢,它是對一列的值進行計算,然后返回一個結果值。另外聚合函數會忽略空值

五個聚合函數:count sum max min avg

聚合函數寫在select后字段名的地方:

Select 字段名 from 表名

Select count(age) from 表名;

// 統計所有數據個數:
select count(*) from 表名;

分組查詢

使用group by語句對查詢信息進行分組,將分組字段結果中相同內容作為一組;

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

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

  • 分組的目的就是為了統計,一般分組查詢會跟聚合函數一起搭配使用;

  • 分組后聚合函數不是操作所有數據,而是操作一組數據。

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

注意:當我們使用某個字段分組,在查詢的時候也需要將這個字段查詢出來,否則看不到數據屬于哪個組的

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

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

having和where的區別:

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

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

offset指的是偏移量,可以認為是跳過的記錄數量,默認為0

length是指需要顯示的總記錄數

 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相當于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中除了數值類型,其他字段類型的值必須使用引號引起,建議單引號
desc 表名:查看表結構
子查詢就是在主select 里面套select from, 相當于從一個結果集里面去查詢。子查詢一般都寫在括號里面,然后在括號外面用as接收這個子查詢出來的值

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 228,316評論 6 531
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 98,481評論 3 415
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 176,241評論 0 374
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 62,939評論 1 309
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 71,697評論 6 409
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,182評論 1 324
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,247評論 3 441
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,406評論 0 288
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 48,933評論 1 334
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 40,772評論 3 354
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 42,973評論 1 369
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,516評論 5 359
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,209評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,638評論 0 26
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,866評論 1 285
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,644評論 3 391
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 47,953評論 2 373

推薦閱讀更多精彩內容