主頁 > 資料庫 > 【技識訓累】Mysql中的SQL語言【技術篇】【一】

【技識訓累】Mysql中的SQL語言【技術篇】【一】

2023-07-12 08:50:53 資料庫

資料庫管理操作

創建一個新的資料庫

要在MySQL中創建一個新的資料庫,可以使用CREATE DATABASE陳述句,以下是創建新資料庫的SQL陳述句及其解釋:

SQL陳述句:

CREATE DATABASE database_name;

解釋:
- CREATE DATABASE是MySQL中用于創建新資料庫的關鍵字,
- database_name是要創建的資料庫的名稱,可以根據需要自定義資料庫名稱,

例如,要創建一個名為"mydatabase"的新資料庫,可以執行以下SQL陳述句:

CREATE DATABASE mydatabase;

執行此SQL陳述句后,MySQL將創建一個名為"mydatabase"的新資料庫,

洗掉一個資料庫

要在MySQL中洗掉一個資料庫,可以使用DROP DATABASE陳述句,以下是洗掉資料庫的SQL陳述句及其解釋:

SQL陳述句:

DROP DATABASE database_name;

解釋:
- DROP DATABASE是MySQL中用于洗掉資料庫的關鍵字,
- database_name是要洗掉的資料庫的名稱,指定要洗掉的資料庫的名稱,

例如,要洗掉名為"mydatabase"的資料庫,可以執行以下SQL陳述句:

DROP DATABASE mydatabase;

執行此SQL陳述句后,MySQL將洗掉名為"mydatabase"的資料庫及其所有相關的表和資料,請注意,洗掉資料庫是一個不可逆的操作,請謹慎使用,

選擇資料庫

在MySQL中選擇資料庫,可以使用USE陳述句,以下是選擇資料庫的SQL陳述句及其解釋:

選擇資料庫:
SQL陳述句:

USE database_name;

解釋:
- USE是MySQL中用于選擇資料庫的關鍵字,
- database_name是要選擇的資料庫的名稱,指定要選擇的資料庫的名稱,

例如,要選擇名為"mydatabase"的資料庫,可以執行以下SQL陳述句:

USE mydatabase;

執行此SQL陳述句后,MySQL將切換到名為"mydatabase"的資料庫,并將其設定為當前活動資料庫,此后,所有的SQL操作將在該資料庫上執行,

請注意,選擇資料庫是一個臨時操作,只在當前會話中有效,如果需要在其他會話中選擇相同的資料庫,需要再次執行USE陳述句,

備份恢復資料庫

要在MySQL中備份和恢復資料庫,可以使用mysqldump和mysql命令列工具,以下是備份和恢復資料庫的SQL陳述句及其解釋:

備份資料庫:
SQL陳述句:

mysqldump -u username -p database_name > backup.sql

解釋:
- mysqldump是MySQL提供的用于備份資料庫的命令列工具,
- -u引數用于指定用戶名,-p引數用于提示輸入密碼,
- database_name是要備份的資料庫的名稱,
- > backup.sql表示將備份的資料匯出到名為backup.sql的檔案中,

例如,要備份名為"mydatabase"的資料庫,可以執行以下SQL陳述句:

mysqldump -u root -p mydatabase > backup.sql

執行此SQL陳述句后,MySQL將備份名為"mydatabase"的資料庫,并將備份資料保存在backup.sql檔案中,

恢復資料庫:
SQL陳述句:

mysql -u username -p database_name < backup.sql

解釋:
- mysql是MySQL提供的用于恢復資料庫的命令列工具,
- -u引數用于指定用戶名,-p引數用于提示輸入密碼,
- database_name是要恢復的資料庫的名稱,
- < backup.sql表示從backup.sql檔案中匯入資料進行恢復,

例如,要恢復名為"mydatabase"的資料庫,可以執行以下SQL陳述句:

mysql -u root -p mydatabase < backup.sql

執行此SQL陳述句后,MySQL將從backup.sql檔案中匯入資料,并恢復到名為"mydatabase"的資料庫中,

請注意,在執行備份和恢復操作時,確保提供正確的用戶名、密碼和資料庫名稱,并確保備份檔案存在且可訪問,

表的管理操作

創建資料表

要在MySQL中創建表,可以使用CREATE TABLE陳述句,以下是創建表的SQL陳述句及其解釋:

創建表:
SQL陳述句:

CREATE TABLE table_name (
    column1 datatype constraint,
    column2 datatype constraint,
    ...
);

解釋:
- CREATE TABLE是MySQL中用于創建表的關鍵字,
- table_name是要創建的表的名稱,可以根據需要自定義表名稱,
- column1, column2等是表中的列名,可以根據需要自定義列名,
- datatype是列的資料型別,指定列中存盤的資料型別,如INT、VARCHAR、DATE等,
- constraint是列的約束條件,用于限制列中的資料,如PRIMARY KEY、NOT NULL、FOREIGN KEY等,

例如,要創建一個名為"customers"的表,包含id、name和email列,可以執行以下SQL陳述句:

CREATE TABLE customers (
    id INT PRIMARY KEY,
    name VARCHAR(50) NOT NULL,
    email VARCHAR(100)
);

執行此SQL陳述句后,MySQL將創建一個名為"customers"的表,其中包含id、name和email三個列,id列被指定為主鍵,name列被指定為非空列,email列沒有約束條件,

請注意,在創建表時,需要指定列名、資料型別和約束條件,并根據需要進行自定義,

洗掉資料表

要在MySQL中洗掉表,可以使用DROP TABLE陳述句,以下是洗掉表的SQL陳述句及其解釋:

洗掉表: SQL陳述句:

DROP TABLE table_name;

解釋:

  • DROP TABLE是MySQL中用于洗掉表的關鍵字,
  • table_name是要洗掉的表的名稱,指定要洗掉的表的名稱,

例如,要洗掉名為"customers"的表,可以執行以下SQL陳述句:

DROP TABLE customers;

執行此SQL陳述句后,MySQL將洗掉名為"customers"的表及其所有相關的資料和結構,請注意,洗掉表是一個不可逆的操作,請謹慎使用,

請注意,在執行洗掉表操作時,確保提供正確的表名稱,并且要洗掉的表不存在任何重要的資料,

修改資料表

要在MySQL中修改表,可以使用ALTER TABLE陳述句,以下是修改表的SQL陳述句及其解釋:

修改表:
SQL陳述句:

ALTER TABLE table_name
    ADD column_name datatype constraint,
    MODIFY column_name datatype constraint,
    DROP column_name;

解釋:
- ALTER TABLE是MySQL中用于修改表的關鍵字,
- table_name是要修改的表的名稱,指定要修改的表的名稱,
- ADD關鍵字用于添加新的列到表中,指定要添加的列名、資料型別和約束條件,
- MODIFY關鍵字用于修改表中已有列的資料型別或約束條件,指定要修改的列名、新的資料型別和約束條件,
- DROP關鍵字用于洗掉表中的列,指定要洗掉的列名,

例如,要向名為"customers"的表中添加一個新的列"phone",可以執行以下SQL陳述句:

ALTER TABLE customers
    ADD phone VARCHAR(20) NOT NULL;

執行此SQL陳述句后,MySQL將向"customers"表中添加一個名為"phone"的新列,該列的資料型別為VARCHAR(20),并且被指定為非空列,

要修改"customers"表中的"email"列的資料型別,可以執行以下SQL陳述句:

ALTER TABLE customers
    MODIFY email VARCHAR(150);

執行此SQL陳述句后,MySQL將修改"customers"表中的"email"列的資料型別為VARCHAR(150),

要洗掉"customers"表中的"phone"列,可以執行以下SQL陳述句:

ALTER TABLE customers
    DROP phone;

執行此SQL陳述句后,MySQL將從"customers"表中洗掉"phone"列,

請注意,在執行修改表操作時,確保提供正確的表名稱、列名稱和相應的修改內容,

重命名資料表

要在MySQL中重命名表,可以使用RENAME TABLE陳述句,以下是重命名表的SQL陳述句及其解釋:

重命名表: SQL陳述句:

RENAME TABLE old_table_name TO new_table_name;

解釋:

  • RENAME TABLE是MySQL中用于重命名表的關鍵字,
  • old_table_name是要重命名的表的名稱,指定要重命名的表的名稱,
  • new_table_name是新的表名稱,指定要將表重命名為的新名稱,

例如,要將名為"customers"的表重命名為"clients",可以執行以下SQL陳述句:

RENAME TABLE customers TO clients;

執行此SQL陳述句后,MySQL將重命名"customers"表為"clients",現在,原來的"customers"表將不再存在,而新的表名稱為"clients",

請注意,在執行重命名表操作時,確保提供正確的表名稱和新的表名稱,并且新的表名稱在資料庫中是唯一的,

資料操作

插入資料

要在MySQL中插入資料到表中,可以使用INSERT INTO陳述句,以下是插入資料的SQL陳述句及其解釋:

插入資料: SQL陳述句:

INSERT INTO table_name (column1, column2, ...) VALUES (value1, value2, ...);

解釋:

  • INSERT INTO是MySQL中用于插入資料的關鍵字,
  • table_name是要插入資料的表的名稱,指定要插入資料的表的名稱,
  • column1, column2等是要插入資料的列名,可以根據需要指定要插入資料的列,
  • value1, value2等是要插入的實際資料值,與列名一一對應,

例如,要向名為"customers"的表中插入一條新的資料,包含id、name和email列,可以執行以下SQL陳述句:

INSERT INTO customers (id, name, email) VALUES (1, 'John Doe', '[email protected]');

執行此SQL陳述句后,MySQL將向"customers"表中插入一條新的資料,id為1,name為'John Doe',email為'[email protected]',

請注意,在執行插入資料操作時,確保提供正確的表名稱、列名和相應的資料值,并且資料值的型別與列的資料型別相匹配,

查詢資料

要在MySQL中查詢資料,可以使用SELECT陳述句,以下是查詢資料的SQL陳述句及其解釋:

查詢資料: SQL陳述句:

SELECT column1, column2, ... FROM table_name WHERE condition;

解釋:

  • SELECT是MySQL中用于查詢資料的關鍵字,
  • column1, column2等是要查詢的列名,可以根據需要指定要查詢的列,使用*表示查詢所有列,
  • FROM關鍵字后面是要查詢的表的名稱,指定要查詢資料的表的名稱,
  • WHERE關鍵字用于指定查詢的條件,可以根據需要使用各種條件運算子和邏輯運算子來構建查詢條件,

例如,要查詢名為"customers"表中的所有資料,可以執行以下SQL陳述句:

SELECT * FROM customers;

執行此SQL陳述句后,MySQL將回傳"customers"表中的所有資料,

要查詢"customers"表中名為"John Doe"的客戶的資訊,可以執行以下SQL陳述句:

SELECT * FROM customers WHERE name = 'John Doe';

執行此SQL陳述句后,MySQL將回傳"customers"表中名為"John Doe"的客戶的所有資訊,

請注意,在執行查詢資料操作時,確保提供正確的表名稱、列名和查詢條件,并且查詢條件與表中的資料型別相匹配,

更新資料

要在MySQL中更新資料,可以使用UPDATE陳述句,以下是更新資料的SQL陳述句及其解釋:

更新資料: SQL陳述句:

UPDATE table_name SET column1 = value1, column2 = value2, ... WHERE condition;

解釋:

  • UPDATE是MySQL中用于更新資料的關鍵字,
  • table_name是要更新資料的表的名稱,指定要更新資料的表的名稱,
  • SET關鍵字用于指定要更新的列和對應的新值,可以根據需要指定要更新的列和相應的新值,
  • WHERE關鍵字用于指定更新的條件,可以根據需要使用各種條件運算子和邏輯運算子來構建更新條件,

例如,要將名為"customers"表中名為"John Doe"的客戶的email更新為新的值,可以執行以下SQL陳述句:

UPDATE customers SET email = '[email protected]' WHERE name = 'John Doe';

執行此SQL陳述句后,MySQL將更新"customers"表中名為"John Doe"的客戶的email為'[email protected]',

請注意,在執行更新資料操作時,確保提供正確的表名稱、列名、新值和更新條件,并且更新條件與表中的資料型別相匹配,

洗掉資料

要在MySQL中洗掉資料,可以使用DELETE陳述句,以下是洗掉資料的SQL陳述句及其解釋:

洗掉資料:
SQL陳述句:

DELETE FROM table_name
WHERE condition;

解釋:
- DELETE FROM是MySQL中用于洗掉資料的關鍵字,
- table_name是要洗掉資料的表的名稱,指定要洗掉資料的表的名稱,
- WHERE關鍵字用于指定洗掉的條件,可以根據需要使用各種條件運算子和邏輯運算子來構建洗掉條件,

例如,要洗掉名為"customers"表中名為"John Doe"的客戶的資料,可以執行以下SQL陳述句:

DELETE FROM customers
WHERE name = 'John Doe';

執行此SQL陳述句后,MySQL將洗掉"customers"表中名為"John Doe"的客戶的資料,

請注意,在執行洗掉資料操作時,確保提供正確的表名稱和洗掉條件,并且洗掉條件與表中的資料型別相匹配,同時,要謹慎操作洗掉資料,以免誤刪重要資料,

在黑夜里夢想著光,心中覆寫悲傷,在悲傷里忍受孤獨,空守一絲溫暖, 我的淚水是無底深海,對你的愛已無言,相信無盡的力量,那是真愛永在, 我的信仰是無底深海,澎湃著心中火焰,燃燒無盡的力量,那是忠誠永在,

轉載請註明出處,本文鏈接:https://www.uj5u.com/shujuku/557070.html

標籤:MySQL

上一篇:達夢實時主備搭建技術分享

下一篇:返回列表

標籤雲
其他(162426) Python(38274) JavaScript(25531) Java(18294) C(15239) 區塊鏈(8275) C#(7972) AI(7469) 爪哇(7425) MySQL(7295) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5876) 数组(5741) R(5409) Linux(5347) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4615) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2438) ASP.NET(2404) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) HtmlCss(1998) .NET技术(1986) 功能(1967) Web開發(1951) C++(1942) python-3.x(1918) 弹簧靴(1913) xml(1889) PostgreSQL(1882) .NETCore(1863) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • GPU虛擬機創建時間深度優化

    **?桔妹導讀:**GPU虛擬機實體創建速度慢是公有云面臨的普遍問題,由于通常情況下創建虛擬機屬于低頻操作而未引起業界的重視,實際生產中還是存在對GPU實體創建時間有苛刻要求的業務場景。本文將介紹滴滴云在解決該問題時的思路、方法、并展示最終的優化成果。 從公有云服務商那里購買過虛擬主機的資深用戶,一 ......

    uj5u.com 2020-09-10 06:09:13 more
  • 可編程網卡芯片在滴滴云網路的應用實踐

    **?桔妹導讀:**隨著云規模不斷擴大以及業務層面對延遲、帶寬的要求越來越高,采用DPDK 加速網路報文處理的方式在橫向縱向擴展都出現了局限性。可編程芯片成為業界熱點。本文主要講述了可編程網卡芯片在滴滴云網路中的應用實踐,遇到的問題、帶來的收益以及開源社區貢獻。 #1. 資料中心面臨的問題 隨著滴滴 ......

    uj5u.com 2020-09-10 06:10:21 more
  • 滴滴資料通道服務演進之路

    **?桔妹導讀:**滴滴資料通道引擎承載著全公司的資料同步,為下游實時和離線場景提供了必不可少的源資料。隨著任務量的不斷增加,資料通道的整體架構也隨之發生改變。本文介紹了滴滴資料通道的發展歷程,遇到的問題以及今后的規劃。 #1. 背景 資料,對于任何一家互聯網公司來說都是非常重要的資產,公司的大資料 ......

    uj5u.com 2020-09-10 06:11:05 more
  • 滴滴AI Labs斬獲國際機器翻譯大賽中譯英方向世界第三

    **桔妹導讀:**深耕人工智能領域,致力于探索AI讓出行更美好的滴滴AI Labs再次斬獲國際大獎,這次獲獎的專案是什么呢?一起來看看詳細報道吧! 近日,由國際計算語言學協會ACL(The Association for Computational Linguistics)舉辦的世界最具影響力的機器 ......

    uj5u.com 2020-09-10 06:11:29 more
  • MPP (Massively Parallel Processing)大規模并行處理

    1、什么是mpp? MPP (Massively Parallel Processing),即大規模并行處理,在資料庫非共享集群中,每個節點都有獨立的磁盤存盤系統和記憶體系統,業務資料根據資料庫模型和應用特點劃分到各個節點上,每臺資料節點通過專用網路或者商業通用網路互相連接,彼此協同計算,作為整體提供 ......

    uj5u.com 2020-09-10 06:11:41 more
  • 滴滴資料倉庫指標體系建設實踐

    **桔妹導讀:**指標體系是什么?如何使用OSM模型和AARRR模型搭建指標體系?如何統一流程、規范化、工具化管理指標體系?本文會對建設的方法論結合滴滴資料指標體系建設實踐進行解答分析。 #1. 什么是指標體系 ##1.1 指標體系定義 指標體系是將零散單點的具有相互聯系的指標,系統化的組織起來,通 ......

    uj5u.com 2020-09-10 06:12:52 more
  • 單表千萬行資料庫 LIKE 搜索優化手記

    我們經常在資料庫中使用 LIKE 運算子來完成對資料的模糊搜索,LIKE 運算子用于在 WHERE 子句中搜索列中的指定模式。 如果需要查找客戶表中所有姓氏是“張”的資料,可以使用下面的 SQL 陳述句: SELECT * FROM Customer WHERE Name LIKE '張%' 如果需要 ......

    uj5u.com 2020-09-10 06:13:25 more
  • 滴滴Ceph分布式存盤系統優化之鎖優化

    **桔妹導讀:**Ceph是國際知名的開源分布式存盤系統,在工業界和學術界都有著重要的影響。Ceph的架構和演算法設計發表在國際系統領域頂級會議OSDI、SOSP、SC等上。Ceph社區得到Red Hat、SUSE、Intel等大公司的大力支持。Ceph是國際云計算領域應用最廣泛的開源分布式存盤系統, ......

    uj5u.com 2020-09-10 06:14:51 more
  • es~通過ElasticsearchTemplate進行聚合~嵌套聚合

    之前寫過《es~通過ElasticsearchTemplate進行聚合操作》的文章,這一次主要寫一個嵌套的聚合,例如先對sex集合,再對desc聚合,最后再對age求和,共三層嵌套。 Aggregations的部分特性類似于SQL語言中的group by,avg,sum等函式,Aggregation ......

    uj5u.com 2020-09-10 06:14:59 more
  • 爬蟲日志監控 -- Elastc Stack(ELK)部署

    傻瓜式部署,只需替換IP與用戶 導讀: 現ELK四大組件分別為:Elasticsearch(核心)、logstash(處理)、filebeat(采集)、kibana(可視化) 下載均在https://www.elastic.co/cn/downloads/下tar包,各組件版本最好一致,配合fdm會 ......

    uj5u.com 2020-09-10 06:15:05 more
最新发布
  • 【技識訓累】Mysql中的SQL語言【技術篇】【一】

    博客推行版本更新,成果積累制度,已經寫過的博客還會再次更新,不斷地琢磨,高質量高數量都是要追求的,工匠精神是學習必不可少的精神。因此,大家有何建議歡迎在評論區踴躍發言,你們的支持是我最大的動力,你們敢投,我就敢肝 ......

    uj5u.com 2023-07-12 08:50:53 more
  • 達夢實時主備搭建技術分享

    在部分作業場景下可能會使用到達夢資料庫的資料守護功能,本文介紹達夢資料守護服務的搭建。 此次搭建使用三臺機器,一主一備一監視器。其中主備資料庫需要提前初始化。一、資料準備需要保證主備庫資料一直,這里使用dmrman脫機備份還原方式進行。停止主庫,進行rman全備。 ./dmrman CTLSTMT= ......

    uj5u.com 2023-07-11 08:48:52 more
  • 達夢實時主備搭建技術分享

    在部分作業場景下可能會使用到達夢資料庫的資料守護功能,本文介紹達夢資料守護服務的搭建。 此次搭建使用三臺機器,一主一備一監視器。其中主備資料庫需要提前初始化。一、資料準備需要保證主備庫資料一直,這里使用dmrman脫機備份還原方式進行。停止主庫,進行rman全備。 ./dmrman CTLSTMT= ......

    uj5u.com 2023-07-11 08:43:21 more
  • 選讀SQL經典實體筆記04_日期運算(上)

    ![](https://img2023.cnblogs.com/blog/3076680/202307/3076680-20230710222226297-1155867049.png) # 1. 年月日加減法 ## 1.1. DB2 ### 1.1.1. sql ```sql select hir ......

    uj5u.com 2023-07-11 08:16:32 more
  • 嵌入式資料庫簡介

    ### 什么是嵌入式資料庫? 嵌入式資料庫主要有兩種定義: - 用于嵌入式系統(如移動設備或消費電子產品)的資料庫。嵌入式資料庫需要占用空間小,并在記憶體和CPU能力有限的環境中提供足夠的性能。 - 嵌入到應用程式中的資料庫--這意味著應用程式不與資料庫服務器通信,而是內置資料庫組件。這種型別的資料庫 ......

    uj5u.com 2023-07-11 08:16:09 more
  • TiDB簡述及TiKV的資料結構與存盤

    本文主要從TiDB的各類組件為起點,了解它的基礎架構,并重點分析它在存盤架構方面的設計,探究其如何組織資料,Table中的每行記錄是如何在記憶體和磁盤中進行存盤的。 ......

    uj5u.com 2023-07-11 08:16:01 more
  • 一站式運維管家 ChengYing 主機接入原理決議

    之前的文章中,我們已經為大家介紹了 [ChengYing](https://github.com/DTStack/chengying) 的安裝原理、產品包制作、產品線部署等內容,本篇將和大家介紹一個困擾許多開發者的內容——ChengYing 主機接入。幫助所有對 ChengYing 感興趣的開發者更 ......

    uj5u.com 2023-07-11 08:15:47 more
  • MySQL之InnoDB存盤結構

    InnoDB存盤引擎最早由Innobase Oy公司開發(屬第三方存盤引擎)。從MySQL 5.5版本開始作為表的默認存盤引擎。該存盤引擎是第一個完整支持ACID事務的MySQL存盤引擎,特點是行鎖設計、支持MVCC、支持外鍵、提供一致性非鎖定讀,非常適合OLTP場景的應用使用。目前也是應用最廣泛的... ......

    uj5u.com 2023-07-11 08:15:37 more
  • 麒麟V10作業系統安裝達夢DM8常見問題分享

    一、麒麟V10關閉防火墻 kylinV10系統或linux系統關閉啟動防火墻開啟防火墻并設定開機自啟啟動: systemctl start firewalld關閉: systemctl stop firewalld查看狀態: systemctl status firewalld開機禁用 : syst ......

    uj5u.com 2023-07-11 08:15:29 more
  • 選讀SQL經典實體筆記04_日期運算(上)

    ![](https://img2023.cnblogs.com/blog/3076680/202307/3076680-20230710222226297-1155867049.png) # 1. 年月日加減法 ## 1.1. DB2 ### 1.1.1. sql ```sql select hir ......

    uj5u.com 2023-07-11 08:15:10 more