第六天MySQL

来源:https://www.cnblogs.com/jane315/archive/2020/05/09/12861095.html
-Advertisement-
Play Games

DDL語言庫與表的管理(創建、修改、刪除)、一些常見的數據類型(整形、浮點|定點、日期,字元) ...


 

2020 5/9

 

二十二、DDL(數據定義語言)->用於庫和表的管理

一、 庫的管理

a)        創建

b)       修改

c)        刪除

二、 表的管理

a)        創建: create

b)       修改: alter

c)        刪除: drop

#庫的管理

1.庫的創建

語法:

create database [if not exists] 庫名;(if not exists->是為了提高容錯性,沒有就創建、有的就不創建)

如:CREATE  DATABASE if not exists books;

 

2.庫的修改(基本上不修改,若想修改庫名,則需要在服務端的data里修改)

修改庫的字元集:

ALTER DATABASE 庫名 CHARACTER SET 字元集;

如:

ALTER DATABASE books CHARACTER SET gbk;

3.庫的刪除

DROP DATABASE IF EXISTS庫名;

如:DROP DATABASE IF EXISTS books;

 

#表的管理

 

1.表的創建

語法:

create table(if not exists) 表名(

        列名 類型[(長度) 約束],

        列名 類型[(長度) 約束],

        列名 類型[(長度) 約束],

        …

        列名 類型[(長度) 約束]

);

 

案例:

CREATE TABLE emp5(

       id INT(7),

       First_name VARCHAR(25),

       Last_name VARCHAR(25),

       Dept_id INT(7)

); (可使用if not exists來提高容錯性)

查看表結構:

 

 

2.表的修改

①     修改列名

②     修改列的類型或約束

③     添加新列

④     刪除列

⑤     修改表名

語法:

alter table 表名 change|modify|drop|add column 列名 【列類型 約束】;

 

#修改列名

語法:

ALTER TABLE 表名 CHANGE COLUMN舊列名 新列名 新類型(一定要加上);

案例:把Last_name欄位名稱改為last_name;

ALTER TABLE emp5 CHANGE COLUMN Last_name last_name VARCHAR(30);

#修改列的類型或約束

語法:ALTER TABLE 表名 CHANGE COLUMN列名 新類型或約束;

案例:修改了last_name欄位的長度

ALTER TABLE emp5 MODIFY COLUMN last_name VARCHAR(49);

#添加新列

語法:

ALTER TABLE 表名 ADD 新列名 新類型【約束】;

案例:向表中添加新列test_column,類型自定義

ALTER TABLE emp5 ADD COLUMN test_column VARCHAR(25);

#刪除列

語法:

ALTER TABLE emp5 ADD COLUMN test_column VARCHAR(25);

案例:刪除表中的test_column欄位

ALTER TABLE emp5 DROP COLUMN test_column;

語法:

ALTER TABLE 表名 RENAME [TO] 新表名;

案例:把表名重命名為emp6;

ALTER TABLE emp5  RENAME TO emp6;

 

3.表的刪除

語法:

drop table 表名;

案例:

DROP TABLE 【if exists】emp6;(可使用if exists來提高容錯性)

  1. 表的複製

#僅僅複製表的結構(使用LIKE關鍵字)

CREATE TABLE employees2 Like employees;

 

 

 

#複製表的數據+結構(使用子查詢)

CREATE TABLE employee3

SELECT * FROM employees;

 

 

#只複製部分表的數據(使用帶篩選條件的子查詢)

CREATE TABLE employee4

SELECT * FROM employees

WHERE employee_id>150;

 

#僅僅複製某些欄位(不攜帶數據)

CREATE TABLE employee5

SELECT job_id,department_id FROM employees

WHERE 1=0;(只要where後的篩選條件不成立,那麼就不會接待數據)

 

 

 

二十三、常見的數據類型

分類:

數值型:

       整形

       小數:

              浮點型

              定點型

字元型:

       較短的文本:char、varchar

       較長的文本:text、bolb(較長的二進位數據)

#整形

類型                     tinyint  smallint    mediumint   int/integer    bigint

所占位元組大小         1         2             3                  4                  8

特點:

①     如果不設置有符號還是無符號,則預設為有符號,如果想設置為無符號,則需要添加unsigned關鍵字

②     如果要插入的數據超出了整形的範圍,會報出out of range異常,並且插入臨界值

③     如果不設置長度,則系統會有預設的長度

④     類型中的長度欄位代表的是顯示數據的最大寬度,若數據小於該長度則會用0在左邊填充,但必須搭配zerofull關鍵字使用(此時預設為無符號整形)

 

#小數

1.浮點型

a)        float(M,D)

b)       double(M,D)

2.定點型

a)        dec(M,D)

b)       decimal(M,D)

特點:

①     M代表的是整數和小數部分的總長度,D代表的是小數部位的長度,若超過範圍則插入臨界值

②     M和D度可以省略,如果是float和double,則會根據插入的數值來決定精度,如果是decimal,則M預設為10,D預設為0

③     定點型的精度較高,如果需要求插入的數值類型精度較高如貨幣元素那則可以考慮使用

使用原則:所選擇的類型越簡單越好,能保存的數值的類型越小越好

 

#字元型

1.較短的文本

char(M)

varchar(M)

binary和varbinary(包含二進位文本字元串)

enum->枚舉類型,要求插入的值必須屬於列表中指定的值之一

set->集合類型,和Enum類型類似,裡面可以保存0~64個成,一次可以選取多個成員

2.較長的文本

text

bolb(較長的二進位數據)

特點:

①     關於char 和varchar

                 寫法                      M的意思                                                  特點                   空間的耗費

char        char(M)          最大的字元數(可以省略,預設為1)      固定長度的字元              高

varchar    varchar(M)    最大的字元數(不可省略)                       可變長度的字元              低

關於固定與可變長度,那“數字”舉例,char會給它分配M個字元大小的空間,而varchar 就給它分配2個空間,長度隨輸入的值變化

 

#日期型

 

date:只保存日期

time:只保存時間

year:只保存年

                            位元組         範圍             時區等的影響

datetime                8          1000-9999              受

timestamp             4           1970-2038            不受

 

具體如下:

CREATE TABLE tab_date(

                     t1 DATETIME,

                     t2 TIMESTAMP

);#創建表

 

INSERT INTO tab_date VALUES(now(),now());

SELECT * FROM tab_date;

 

 

 

show VARIABLES like 'time_zone';

set time_zone ='+9:00';#改變時區

 

可發現改變時區後,t2的值發生變化,受到了時區的影響

 


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

-Advertisement-
Play Games
更多相關文章
  • Linux常用命令大全(非常全!!!) 最近都在和Linux打交道,感覺還不錯。我覺得Linux相比windows比較麻煩的就是很多東西都要用命令來控制,當然,這也是很多人喜歡linux的原因,比較短小但卻功能強大。我將我瞭解到的命令列舉一下,僅供大家參考: 系統信息 arch 顯示機器的處理器架構 ...
  • linux進程,這塊太難了,太多命令,太多新概念.作為初學者戰戰兢兢.同時也在匍匐前進. ...
  • Linux內核在啟動時會列印出內核記憶體空間的佈局圖,下麵是ARM Vexpress平臺列印出來的記憶體空間佈局圖: 這部分信息列印是在mem_init()函數中實現的。 編譯器在編譯目標文件並且鏈接完成之後,就可以知道內核映像文件最終的大小,接下來打包成二進位文件,該操作由 控制,其中也劃定了內核的內 ...
  • 常用選項: -i #直接修改目標文件內容. -n #取消預設輸出. 實例: #刪除 sed -i '/content/d' temp.txt #刪除中temp.txt匹配content內容的行. sed -i '/^$/d' temp.txt #刪除文件中所有空行. sed -i 'nd' temp ...
  • public static class QueryableExtension { public static IQueryable<T> Paged<T>(this IQueryable<T> query, Expression<Func<T, object>> expression, OrderB ...
  • 十四、讀寫分離 Atlas架構 1、安裝軟體 2、修改配置 3、啟動atlas 4、測試 5、管理atlas 6、擴展——atlas 自動分表 ...
  • 十三、mysql高可用 1、普通主從複製架構存在的不足 高可用? 業務不間斷的工作。 用戶的體驗不出來業務斷點。 普通主從環境,存在的問題: 2、企業高可用解決方案: MMM(過時) MHA(目前推薦) PXC、Galera Cluster(出現很多年,企業很少用) 5.7.17 MGR 、Inno ...
  • 十二、mysql主從複製 1、主從複製原理 1.主從複製的前提: 1.1兩台mysql實例(多台物理機,或者多實例) 1.2主庫要開啟二進位日誌 1.3主庫要提供複製相關用戶,replication slave,一個比較特殊的許可權。 1.4從庫需要將和主庫相差的數據,進行追加 一般情況下可以人為備份 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...