MySql 常用命令總結

来源:https://www.cnblogs.com/zhaoyanjun/archive/2018/04/25/8944374.html
-Advertisement-
Play Games

註意事項: sql 使用單引號來環繞文本值(大部分資料庫系統也接受雙引號)。如果是數值,請不要使用引號。 一、資料庫 1、創建資料庫 創建一個名字為lesson的資料庫 2、刪除資料庫 二:表 1、創建表 CREATE TABLE .`it` ( INT NOT NULL, VARCHAR(45) ...


註意事項:

sql 使用單引號來環繞文本值(大部分資料庫系統也接受雙引號)。如果是數值,請不要使用引號。

一、資料庫

1、創建資料庫

CREATE DATABASE lesson ;

創建一個名字為lesson的資料庫

2、刪除資料庫

drop database lesson ;

二:表

1、創建表

CREATE TABLE `mydb`.`it` (
      `id` INT NOT NULL,
      `name` VARCHAR(45) NULL,
      PRIMARY KEY (`id`)
 );

在名字為mydb的資料庫中創建一個表,表的名字叫it.

表中有兩個欄位 : id , name 。 其中主鍵為 id

2、刪除表

DROP TABLE `mydb`.`it`;

資料庫名: mydb

表名 : it

3、修改表的名字

RENAME TABLE student TO user ;

把student表的名字改為user

4、複製表

create table table2 select * from user ;

通過複製user表,來創建一個新表table2

三:增加數據

1、往表裡插入數據

INSERT INTO `mydb`.`user` (`id`, `name`, `age`) VALUES ('2', 'lisid', '25');

mydb : 資料庫名

user : 表名

id ,name , age :代表三個欄位
VALUES :欄位對應的數據

四:刪除數據

1、條件刪除(刪除一行數據)

DELETE FROM user WHERE  id=1  ; 

刪除id = 1 的所有數據 (刪除id =1 的這一行)

五、更新數據

1、更新一個欄位的值

UPDATE `mydb`.`user` SET `age`='22' WHERE `id`='1';

數據名: mydb
表名 : user
欄位 : age
篩選條件 : id = 1 ;

在mydb資料庫,user表中,把id = 1 的這一行的 age 屬性值修改為 22

2、更新多個欄位的值

UPDATE `mydb`.`user` SET `name`='奶茶妹妹', `age`='18' WHERE `id`='2'; 

在mydb資料庫,user表中,把id = 2 的這一行的 name屬性值修改為 奶茶妹妹 , age 屬性值修改為 22

六:查詢數據

1、查詢

SELECT * FROM mydb.user;

從mydb資料庫中查詢user表裡面的所有數據

2、單屬性查詢

SELECT name  FROM user ;

從user表中查詢所有的name屬性值

3、多屬性查詢

SELECT name , age  FROM user ;

從user表中查詢所有的name 和 age 的屬性值

4、條件查詢 where

1、根據 id 查詢

SELECT name , age , id  FROM user where id = 2 ;

從user表中查詢id等於2的所有name、age、id 的屬性值,註意id的類型是整型,所以2不用加單引號

2、根據 name 查詢

SELECT name , age , id  FROM user where name = 'tom' ;

從user表中查詢 name 值等於‘tom’ 的所有name、age、id 的屬性值,註意name的類型是字元型,‘tom’加單引號

3、邏輯查詢:大於

SELECT * FROM `user` WHERE id > 5  ;

從user表中查詢 id 值 大於 5 的所有name、age、id 的屬性值
所有的邏輯運算符都支持: 大於 > 、 小於 < 、 大於等於 >= 、 小於等於 <= 、 等於 = 、 不等 != (或者 <>)

4、邏輯查詢:BETWEEN

SELECT * FROM `user` WHERE id BETWEEN 3 AND 8  ;

user : 表名

id : 欄位名

between : 操作符 作用是選取介於兩個值之間的數據範圍

從user表中查詢 id值在3(包含3) 到 (包含8)之間的所有name、age、id 的屬性值 。 也就是 id 大於等於3, 小於等於8之間。

5、邏輯查詢:in

SELECT * FROM `user` WHERE age in ( 12 , 18 )  ;

user : 表名

age : 欄位名

in : 操作符 作用是為查詢條件規定多個值

從user表中查詢出年齡為12歲和18歲的人所有信息。 相當於並集。

5、模糊查詢 like

1、模糊查詢:以某字元開頭

SELECT * FROM student WHERE phone LIKE '1825%'

student : 表名
phone : 欄位名 代表手機號

LIKE : 模糊查詢

% : 代表任意一個或多個字元 , 可匹配任意類型和長度的字元。

從student表中查出以1825開頭的手機號

2、模糊查詢:多個條件

SELECT * FROM student WHERE phone LIKE '182%' AND `name` LIKE 'zhang%'   ;

student : 表名

phone : 欄位名 代表手機號

name : 欄位名 代表名字
從student表中查出以182開頭的手機號並且 名字是以zhang開頭的所有信息

3、模糊查詢:通配符

SELECT * FROM student WHERE phone LIKE '1825110114_'

student : 表名

phone : 欄位名 代表手機號

LIKE : 模糊查詢

_ : 代表一個字元

從student表中查出以1825110114開頭的手機號

5、模糊查詢:包含

SELECT * FROM student WHERE phone LIKE '%114%' ;

student : 表名

phone : 欄位名 代表手機號

LIKE : 模糊查詢

% : 代表任意一個或多個字元 , 可匹配任意類型和長度的字元。
從student表中查出手機號包含114的所有信息

6、模糊查詢:取消通配符

SELECT * FROM student WHERE phone LIKE '%114\%'  ;

student : 表名

phone : 欄位名 代表手機號

LIKE : 模糊查詢

% : 代表任意一個或多個字元 , 可匹配任意類型和長度的字元。

從student表中查出以114%結尾的手機號 , 第一個 % 代表通配符 , % 代表% 字元,沒有通配符的功能

6、數量限制查詢 limit

select * from user order by id limit 3 , 5 ;

從user表中查詢 從3開始(包括3),數量為5 條數據。也就是3、4、5、6、7 條數據

註意5代表的是查詢的數量

7、單欄位排序查詢 order by

order by 語句用於根據指定的列對結果集進行排序,預設按照升序對。

select * from  mydb.`user` order by age ;

mydb : 資料庫名

user : 表名

age : 排序欄位

從user表中查詢所有的信息,查詢結果按照 age 欄位排序。(預設升序)

select * from  mydb.`user` order by age DESC ;  

從user表中查詢所有的信息,查詢結果按照 age 欄位降序排序。

8、多欄位排序查詢 order by

select * from  mydb.`user` order by age DESC , `name` ;  

mydb :資料庫

user :表名

age :年齡

name :名字

從user表中查詢所有的信息,查詢結果按照 age 降序排序。如果年齡相同,就按照name,升序排序 。

9、求總 count()

SELECT COUNT( name ) FROM `user`   ;

name : 欄位名,代表名字

user : 表名

從user表中查詢 name 值得數目,不計 null 值。

SELECT COUNT( * ) FROM `user` ;

查詢user表中的記錄數

SELECT COUNT( DISTINCT `name` ) FROM `user` ;

查詢user表中name欄位不同值的數目,相當於去重。

10、求最大值 max() 和 最小值 min()

MIN 和 MAX 也可用於文本列,以獲得按字母順序排列的最高或最低值。

SELECT MAX( id ) FROM `user` ;

從user表中查詢 id 欄位的最大值

SELECT MIN( id ) FROM `user` ;

從user表中查詢 id 欄位的最小值

11、求和 sum()

SELECT SUM( id ) FROM `user` ;

id : 欄位名

user : 表名

查詢user表中 id 值的和

12、求平均值 avg()

SELECT AVG( id ) FROM `user` ;

id : 欄位名

user : 表名

查詢user表中 id 值的平均數

13、顯示所有資料庫

SHOW DATABASES;

14、顯示所有的表

SHOW TABLES;

七:視圖

1、視圖的基本概念

http://www.cnblogs.com/zzwlovegfj/archive/2012/06/23/2559596.html

2、創建一個視圖

CREATE VIEW myview as SELECT * FROM mydb.`user` ;

myview :視圖的名字

mydb :資料庫的名字

user : 表的名字

查詢user表的所有數據,作為視圖myview的數據

3、刪除視圖

drop view myview ;

myview : 視圖的名字

八:子查詢

1、 查詢 video 表裡面 status 欄位為0 的前5條數據,並且按照 id 降序排列

select t.* from (select * from video where status = 0 limit 5) as t order by t.id desc ; 

這裡的 select * from video where status = 0 limit 5 相當於一個臨時表,用別名t代替。


個人微信號:zhaoyanjun125 , 歡迎關註


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 想用linux虛擬機裝一個oracle,中間遇到的坑太多了,最後總算是安裝好了,一定要寫個全面的教程出來。 話不多說 通用編輯命令: vi test.txt #進入編輯模式 編輯完成後按ESC退出編輯模式 :wq 回車 保存編輯的文件 1.設置linux開機自動打開網路連接,不打開網路連接Secur ...
  • Mysql遠程連接 Host * is not allowed to connect to this MySQL server 解決辦法:在本機登入mysql後,選擇用戶,修改你遠程鏈接的用戶的主機,從 localhost 改為 % ...
  • SQL中的LEFT RIGHT INNER JOIN的區別及學習,僅供參考,如有錯誤,歡迎糾正。 ...
  • 寫在前面: 最近,老項目新增了日報優化的需求,麗姐讓我用觸發器去實現當數據插入或者更新的時候,實現對日報表數據更新操作。嗯嗯嗯呢,之前學習資料庫的時候,有碰到過觸發器,但都是一跳而過,也沒怎麼去真正的實踐,這次就權當再次去學習吧~~ 1.觸發器實例: 上面的觸發器例子,只是一個框架,並不能執行,這裡 ...
  • 最近升級android studio到版本3.0.1後,想要使用FragmentActivity這個類,導入v4包,發現R文件報錯了,也就是找不到的意思。 如圖:導包 此時選中v4包導進去。 確定之後它一下子就跑到這裡來,這是Values文件。查看了一下,還真沒有R文件的相關內容。 再看下build ...
  • 最近版本測試階段,發現一個奇怪的問題,以前在A測試機上出現的崩潰bug,解決後今天在B測試機上又出現了,在B上解決完之後,返回到設備A上發現又不行了。最後調試發現是測試設備系統版本不同導致的,A設備是iOS10的,而B設備是iOS11的,需求是,當點擊自定義的UITableViewCell時,需要它 ...
  • 最近使用cocoapods集成友盟 發現幾個經典錯誤 1.clang: error: linker command failed with exit code 1 (use -v to see invocation) 這個 應該是配置路徑 有問題。 我的解決方案是:找到other link 刪除所有 ...
  • Android studio更新 第一步:在你所在項目文件夾下:你項目根目錄gradlewrapper gradle-wrapper.properties (只要在打開項目的時候選OK,這個文件就會出現) 修改gradle-wrapper.properties最後一行的地址我的是: 1 distri ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...