MySQL的DML和DQL   增刪改查

来源:https://www.cnblogs.com/lsy131479/archive/2018/02/05/8416039.html
-Advertisement-
Play Games

DML和DQL 增刪改查 SELECT * FROM grade --新增 insert -- 向年級表中新增3條數據INSERT INTO grade(gradeID,gradeName) VALUES(4,'4年級');INSERT INTO grade(gradeID,gradeName) V ...



DML和DQL   增刪改查

 

SELECT * FROM grade

--新增 insert

-- 向年級表中新增3條數據
INSERT INTO grade(gradeID,gradeName) VALUES(4,'4年級');
INSERT INTO grade(gradeID,gradeName) VALUES(5,'5年級');
INSERT INTO grade(gradeID,gradeName) VALUES(6,'6年級');

-1.備份表:create table 新表(不存在) select * from 原表
-2.追加數據:
(一次性向表中走N條記錄)
insert into 被追加數據的表名(列) select 列 from 原表

 

-- 刪除 delect

DELETE FROM grade WHERE gradeID>3;
DELETE FROM grade WHERE gradeID=4 OR gradeID=5  OR gradeID=6;
DELETE FROM grade WHERE gradeID IN (4,5,6);

-- 同時插入多條數據  (oracle資料庫不支持)
INSERT INTO grade(gradeID,gradeName)
VALUES(4,'4年級'),(5,'5年級'),(6,'6年級');

--修改 update

-- 修改gradeID=1的年級名稱為 one
UPDATE  grade SET gradeName='one'
WHERE gradeID=1

-- delete 刪除表中所有的數據
DELETE FROM grade;

 

delete 和 truncate的區別
01.delete

begin  (開啟事務)
select  * from  grade;(查詢年級表中所有的數據)
delete  from  grade; (刪除年級表中所有的數據)
select  * from  grade;(查詢年級表中所有的數據,沒有數據)
rollback;  (事務回滾)
select  * from  grade;(查詢年級表中所有的數據,刪除的數據恢復)
commit (提交事務)


02.truncate

begin  (開啟事務)
select  * from  grade;(查詢年級表中所有的數據)
truncate table  grade; (刪除年級表中所有的數據)
select  * from  grade;(查詢年級表中所有的數據,沒有數據)
rollback;  (事務回滾)
select  * from  grade;(查詢年級表中所有的數據,沒有數據)
commit (提交事務)


區別:
  01.delete後面可以拼接where條件,刪除指定的行!
     truncate只能刪除表中所有的數據!不能有where!

  02.delete可以回滾,資料庫可以恢復!(記錄日誌)
     truncate 不能事務混滾,數據不可以恢復!(不記錄日誌)

  03.truncate執行效率高!
     delete執行效率低!   

  04.delete刪除後自增列編號會接著上次最大值
     Truncate截斷表:自增列編號從1開始


查詢

  將查詢結果保存到 新表中!
 create table  newStudent
    (select stuName,address from  student)

  view (視圖) :不占物理空間!

 

  使用 具體的列 代替 *

  select  * from  student;

  select  stuName,age ,address  from  student;


  使用別名

SELECT gradeID AS 年級編號,gradeName  '年級 名稱' FROM grade;

格式
01.  列名  AS  別名
02.  列名   別名
03.  如果別名中有特殊符號,必須把 別名用 單引號 引起來!


查詢年級表中 id不等於1的數據   <>    !=
SELECT gradeID,gradeName
FROM grade
WHERE gradeid <> 1

 


 
+  必須是相同的數據類型,能轉換成2進位的數據!
如果有一個列是null  整體返回null! 

我們通常使用 concat來做合併
SELECT  CONCAT(loginPwd,',',studentNAME) AS  合併列 FROM STUDENT

 

使用is null 的時候 要確保 查詢的列 可以為空!

null:
  01.標識  空值
  02.不是0,也不是空串""
  03.只能出現在定義 允許為null的欄位
  04.只能使用is  null 或者is not null 進行比較!


SELECT *  FROM student
WHERE loginPwd  IS NULL

 


-- 查詢成績表的總成績
SELECT  SUM(studentResult)  FROM result;
-- 查詢成績的平均值
SELECT  AVG(studentResult)  FROM result;
-- 查詢成績的最高分
SELECT  MAX(studentResult)  FROM result;
-- 查詢成績的最低分
SELECT  MIN(studentResult)  FROM result;
-- 查詢有成績的總數
SELECT  COUNT(studentResult)  FROM result;

 

 

#修改表名
ALTER TABLE 舊表名RENAME [TO] 新表名;
#添加欄位
ALTER TABLE 表名ADD 欄位名數據類型[屬性];
#修改欄位
ALTER TABLE 表名CHANGE 原欄位名新欄位名數據類型[屬性];
#刪除欄位
ALTER TABLE 表名DROP 欄位名;


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

-Advertisement-
Play Games
更多相關文章
  • 重寫 class 的 ToString() 來簡化獲取 enum 的 DescriptionAttribute 值 目錄 一、常見的 enum 類型版本 二、演變:class 版本的 enum 類型 三、演進:class 和 enum 兩者共存的版本 一、常見的 enum 類型版本 新建一個 Alg ...
  • 1. 前言 Fall Creators Update中提供了一個新得ColorPicker控制項,解決了以前選擇顏色只能用Combo Box的窘境。 2. 一個簡單的例子 如上所示,ColorPiker可以通過在光譜或色輪上拖動滑塊,或者在RGB/HSV及十六進位的TextBox中直接輸入顏色的數值改 ...
  • 一開始,思路是這樣的: 遺憾的是,將會拋出一個異常: 修改後的實現方式: 或者 : 最後附上SqlHelper: static class SqlHelper { private static readonly string ConnectionString = ConfigurationManag ...
  • ———————————————————————————————————————————————————————————————————————— QQ 是一款熱門的即時通信(IM)類工具,在安裝時刻會向系統分區的 \..\windows\system32\drivers 路徑下生成兩個驅動程式文件: ...
  • Shell 變數 定義變數時,變數名不加美元符號($,PHP語言中變數需要),如: 註意,變數名和等號之間不能有空格,這可能和你熟悉的所有編程語言都不一樣。同時,變數名的命名須遵循如下規則: 首個字元必須為字母(a z,A Z)。 中間不能有空格,可以使用下劃線(_)。 不能使用標點符號。 不能使用 ...
  • 大多數Windows用戶,右鍵中預設新建的文件格式就那麼幾種。這可能對我們愛折騰或者特殊要求的人員來說可能有點不方便,比如說要創建個 .reg .bat .vbs等格式的文件,就需要新建個文本文件修改尾碼為或者是通過對應軟體保存為 .reg .bat .vbs等。是不是有點麻煩喲,可不可以在右鍵中的 ...
  • 索引: 使用索引可快速訪問資料庫表中的特定信息。索引是對資料庫表中一列或多列的值進行排序的一種結構,例如 employee 表的姓(name)列。如果要按姓查找特定職員,與必須搜索表中的所有行相比,索引會幫助您更快地獲得該信息。 索引是一個單獨的、物理的資料庫結構,它是某個表中一列或若幹列值的集合和 ...
  • https://github.com/mono/old-code https://wiki.scn.sap.com/wiki/display/SQLANY/SQL+Anywhere+and+Microsoft+.NET http://www.mono-project.com/docs/databas ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...