day03-MySQL基礎知識02

来源:https://www.cnblogs.com/liyuelian/archive/2022/10/02/16749704.html
-Advertisement-
Play Games

MySQL基礎知識02 4.CRUD 資料庫CRUD語句:增(create)、刪(delete)、改(update)、查(Retrieve) Insert 語句 (添加數據) Update 語句(更新數據) Delete 語句(刪除數據) Select 語句 (查找數據) 指對資料庫中表記錄的操作( ...


MySQL基礎知識02

4.CRUD

資料庫CRUD語句:增(create)、刪(delete)、改(update)、查(Retrieve)

  1. Insert 語句 (添加數據)
  2. Update 語句(更新數據)
  3. Delete 語句(刪除數據)
  4. Select 語句 (查找數據)

指對資料庫中表記錄的操作(DML 操作)

註意:

alter屬於DDL,用來修改基本表,是對錶的結構進行操作,比如對欄位增加,刪除,修改類型;

DML 操例,如update是用來修改表中的數據,修改某一行某一列的值

對行是數據操縱DML(update),對列是數據定義DDL(alter)

4.1Insert語句

  • 使用INSERT 語句向表中插入數據
INSERT INTO tablename [(column [,column ...])]
VALUES 	(value[, value...]);

例子

  1. 創建一商品表goods(id int, goods_name varchar(10),price double);
  2. 添加兩條記錄
# 練習insert語句
-- 1. 創建一商品表goods(id int, goods_name varchar(10),price double);
CREATE TABLE goods(
	id INT,
	goods_name VARCHAR(10),
	price DOUBLE)
	
-- 2. 添加兩條記錄
INSERT INTO goods (id,goods_name,price)
	VALUES(10,'華為手機',2000);
	
INSERT INTO goods (id,goods_name,price)
	VALUES(20,'蘋果手機',3000);

SELECT * FROM goods;
image-20221002184244851
  • INSERT語句註意事項

細節說明:

  1. 插入的數據應該與欄位的數據類型相同,比如把 'abc' 添加到 int 類型會錯誤

  2. 數據的長度應在列的規定範圍之內,例如:不能將一個長度為80的字元串加入到長度為40的列中

  3. 在values中列出的數據位置必須與被加入的列的排列位置對應

  4. 字元和日期型數據應包含在單引號中

  5. 列可以插入空值[前提是該欄位允許為空],insert into table value(null)

  6. insert into table_name(列名...) values (),(),() 形式添加多條記錄

  7. 如果是給表中的所有欄位添加數據,可以不寫前面的欄位名稱

  8. 預設值的使用,當不給某個欄位值時,如果有預設值就會添加預設值,否則報錯

    如果某個列沒有指定not null,那麼當添加數據時,沒有給定值,則會預設給null

    如果我們希望指定某個預設值,可以在創建表時指定

-- - INSERT語句註意事項
-- 細節說明:
-- 1. 插入的數據應該與欄位的數據類型相同
INSERT INTO goods VALUES('北京','小米手機',2000)-- 失敗,id對應的列類型是int

-- 2. 數據的長度應在列的規定範圍之內,例如:不能將一個長度為80的字元串加入到長度為40的列中
INSERT INTO goods VALUES(40,'vovo手機vovovovo手機vovovovo手機vovo',2000)-- 失敗

-- 3. 在values中列出的數據位置必須與被加入的列的排列位置對應
INSERT INTO goods (goods_name,id,price)-- 成功,即使改變了列屬性的位置,只要值是對應的,就ok
	VALUES('vivo手機',50,1800)


-- 4. 字元和日期型數據應包含在單引號中
INSERT INTO goods VALUES(60,小米手機,2000)-- 失敗,字元串應該加上單引號

-- 5. 列可以插入空值[前提是該欄位允許為空],insert into table value(null)
INSERT INTO goods (id,goods_name,price)
	VALUES(11,'boluo手機',NULL)-- 成功,該欄位允許為空

-- 6. insert into table_name(列名...) values (),(),() 形式添加多條記錄
INSERT INTO goods VALUES(13,'三星手機',2300),(14,'四星手機',2300)-- ok

-- 7. 如果是給表中的所有欄位添加數據,可以不寫前面的欄位名稱
INSERT INTO goods (id) VALUES(66); -- ok,指定了欄位

-- 8. 預設值的使用,當不給某個欄位值時,如果有預設值就會添加預設值,否則報錯
	-- 如果某個列沒有指定not null,那麼當添加數據時,沒有給定值,則會預設給null
INSERT INTO goods (id,goods_name) 
	VALUES(88,'格力手機');-- 這裡的price預設設為null
SELECT * FROM goods;
		
-- 如果我們希望指定某個預設值,可以在創建表時指定
-- 例如
CREATE TABLE goods2 (
	id INT ,
	goods_name VARCHAR(10),
	price FLOAT NOT NULL DEFAULT 100);
INSERT INTO goods2 (id,goods_name) VALUES(1,'大西瓜手機');
SELECT * FROM goods2;

goods表:

image-20221002214014175

goods2表:

image-20221002214056677

4.2Update語句

  • 語法:
UPDATE tab_name 
	SET col_name1=expr1[, col_name2=expr2...]
	[WHERE where_definition]

例子

要求:在上面創建的epm表中修改表中的記錄

  1. 將所有員工的薪水改為5000元
  2. 將姓名為‘小妖怪’的員工薪水改為3000元
  3. 將老妖怪的薪水在原有的基礎上加1000元
-- 要求:在上面創建的epm表中修改表中的記錄
SELECT * FROM emp

-- 1. 將所有員工的薪水改為5000元
UPDATE emp SET salary = 5000


-- 2. 將姓名為‘小妖怪’的員工薪水改為3000元
UPDATE emp SET salary = 3000 WHERE user_name = '小妖怪'

-- 3. 將老妖怪的薪水在原有的基礎上加1000元
INSERT INTO emp 
	VALUES(200,'老妖怪','1990-1-1','2004-4-12 12:22:09','捶背的',5000,'給大王捶背','111')
 
 UPDATE emp 
	SET salary = salary + 1000, job='出主意的'
	WHERE user_name = '老妖怪'

image-20221002221709227

  • 使用細節
  1. UPDATE 語法可以用新值更新原有表行中的各列
  2. set子句指示要修改哪些列和要給予哪些值
  3. WHERE子句指定應更新哪些行,如果沒有WHERE子句,則更新所有的記錄。因此要慎用
  4. 如果需要修改多個欄位,可以通過set欄位1=值1,欄位2=值2...

4.3Delete語句

  • 語法
delete from tbl_name 
		[WHERE where_definition]

例子

-- delete語句演示
-- 刪除表中名稱為'老妖怪'的記錄
DELETE FROM emp WHERE user_name ='老妖怪'

-- 刪除表中所有記錄
DELETE FROM emp

SELECT * FROM emp

image-20221002222608594

  • 使用細節
  1. 如果不使用子句,將刪除表中所有數據
  2. delete語句不能刪除某一列的值(可使用update設為null或者 '')
  3. 使用delete語句僅刪除記錄,不刪除表本身。如果要刪除表,使用drop 語句:drop table 表名;

4.4Select語句


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

-Advertisement-
Play Games
更多相關文章
  • 在開發過程中,像側邊欄這種功能的版塊,我們在很多頁面都需要使用到的時候,我們則需要在視圖函數中書寫重覆的代碼,這樣很繁瑣,我們可以將側邊欄製成inclusion_tag,後面我們需要用到側邊欄功能時,只需要導入即可! 將側邊欄製成inclusion_tag的步驟: 1.在應用下創建一個名字必須叫te ...
  • 2022-10-01 關聯查詢: 在Django項目中使用ORM模式設置表後,進行關聯查詢,即兩個表直接有聯繫的查詢。 方式: 可以通過主表查詢從表,也可以通過從表查詢主表。 方式一實例: (1)查詢編號為1的圖書中的人物 前提環境,進入pycharm,進入虛擬環境、進入shell環境。 首先,需要 ...
  • 在本人前一篇博文`《驅動開發:通過ReadFile與內核層通信》`詳細介紹瞭如何使用應用層`ReadFile`系列函數實現內核通信,本篇將繼續延申這個知識點,介紹利用`PIPE`命名管道實現應用層與內核層之間的多次通信方法。 ...
  • 標題是個大命題,場景其實有很多很多,而且千變萬化,一個帖子很難暢聊,以後會慢慢談。說一個最常見的場景。每個員工發張NFC卡,管理者給每人分配的卡裡寫入賬號和密碼,從而實現刷卡自動登錄客戶端系統。我看到這種需求的時候,做了一些研究,發現線上的免費解決方案根本就沒有,既然有需求沒雲端解決方案,我就自己做 ...
  • 簡述 類型:創建型 目的:實現對客戶端中對象族的平替。 對象族 一組對象。比如,華為的手機,筆記本,平板可以統稱為華為族。 我們藉以下案例來說說如何使用抽象工廠模式平替對象族。 優化案例 最初版 public interface Uploader { void upload(String fileN ...
  • 一 引入 項目有個新需求,當點擊或觸碰TextBox時,基於TextBox的相對位置,彈出一個自定義的Keyboard,如下圖所示: 二 KeyboardControl 先實現一個自定義的KeyboardControl,它繼承自Window。 Xaml代碼如下: <Window x:Class="W ...
  • 我們在創建條形碼時,如果以圖片的方式將創建好的條碼保存到指定文件夾路徑,可以在程式中直接載入圖片使用;已生成的條碼圖片,需要通過讀取圖片中的條碼信息,如條碼類型、條碼繪製區域在圖片中的四個頂點坐標位置等,可參考本文中的方法。 註:讀取時,也支持讀取二維碼類型。 引入dll 調用API:Spire.B ...
  • 大家好,我是痞子衡,是正經搞技術的痞子。今天痞子衡給大家介紹的是i.MXRT10xx系列MCU外接24MHz晶振的作用。 痞子衡之前寫過一篇關於時鐘引腳的文章 《i.MXRT1xxx系列MCU時鐘相關功能引腳的作用》,裡面簡單提及了外部晶振相關引腳的作用,但是並沒有詳細展開。最近在客戶支持中,有客戶 ...
一周排行
    -Advertisement-
    Play Games
  • 經常看到有群友調侃“為什麼搞Java的總在學習JVM調優?那是因為Java爛!我們.NET就不需要搞這些!”真的是這樣嗎?今天我就用一個案例來分析一下。 昨天,一位學生問了我一個問題:他建了一個預設的ASP.NET Core Web API的項目,也就是那個WeatherForecast的預設項目模 ...
  • 很多軟體工程師都認為MD5是一種加密演算法,然而這種觀點是不對的。作為一個 1992 年第一次被公開的演算法,到今天為止已經被髮現了一些致命的漏洞。本文討論MD5在密碼保存方面的一些問題。 ...
  • Maven可以使我們在構建項目時需要用到很多第三方類jar包,如下一些常用jar包 而maven的出現可以讓我們避免手動導入jar包出現的某些問題,它可以自動下載那須所需要的jar包 我們只需要在創建的maven項目自動生成的pom.xml中輸入如下代碼 <dependencies> <!--ser ...
  • 來源:https://developer.aliyun.com/article/694020 非同步調用幾乎是處理高併發Web應用性能問題的萬金油,那麼什麼是“非同步調用”? “非同步調用”對應的是“同步調用”,同步調用指程式按照定義順序依次執行,每一行程式都必須等待上一行程式執行完成之後才能執行;非同步調 ...
  • 1.面向對象 面向對象編程是在面向過程編程的基礎上發展來的,它比面向過程編程具有更強的靈活性和擴展性,所以可以先瞭解下什麼是面向過程編程: 面向過程編程的核心是過程,就是分析出實現需求所需要的步驟,通過函數一步一步實現這些步驟,接著依次調用即可,再簡單理解就是程式 從上到下一步步執行,從頭到尾的解決 ...
  • 10瓶毒藥其中只有一瓶有毒至少需要幾隻老鼠可以找到有毒的那瓶 身似浮雲,心如飛絮,氣若游絲。 用二分查找和二進位位運算的思想都可以把死亡的老鼠降到最低。 其中,二進位位運算就是每一隻老鼠代表一個二進位0或1,0就代表老鼠存活,1代表老鼠死亡;根據數學運算 23 = 8、24 = 16,那麼至少需要四 ...
  • 一、Kafka存在哪些方面的優勢 1. 多生產者 可以無縫地支持多個生產者,不管客戶端在使用單個主題還是多個主題。 2. 多消費者 支持多個消費者從一個單獨的消息流上讀取數據,而且消費者之間互不影響。 3. 基於磁碟的數據存儲 支持消費者非實時地讀取消息,由於消息被提交到磁碟,根據設置的規則進行保存 ...
  • 大家好,我是陶朱公Boy。 前言 上一篇文章《關於狀態機的技術選型,最後一個真心好》我跟大家聊了一下關於”狀態機“的話題。從眾多技術選型中我也推薦了一款阿裡開源的狀態機—“cola-statemachine”。 於是就有小伙伴私信我,自己項目也考慮引入這款狀態機,但網上資料實在太少,能不能系統的介紹 ...
  • 使用腳本自動跑實驗(Ubuntu),將實驗結果記錄在文件中,併在實驗結束之後將結果通過郵件發送到郵箱,最後在windows端自動解析成excel表格。 ...
  • 話說在前面,我不是小黑子~ 我是超級大黑子😏 表弟大周末的跑來我家,沒事幹天天騷擾我,搞得我都不能跟小姐姐好好聊天了,於是為了打發表弟,我決定用Python做一個小游戲來消耗一下他的精力,我思來想去,決定把他變成小黑子,於是做了一個坤坤打籃球的游戲,沒想到他還挺愛玩的~ 終於解放了,於是我把游戲寫 ...