MySQL之數據類型與操作數據表

来源:http://www.cnblogs.com/Qian123/archive/2016/04/05/5357114.html
-Advertisement-
Play Games

上節回顧 一、數據類型 什麼是數據類型? 數據類型是指列、存儲過程參數、表達式和局部變數的數據特征,它決定了數據的存儲格式,代表了不同的信息類型。 所謂數據類型,最直接的理解就是我們有些是存儲數字的,而數字當中,我們有時是要存儲為整數,有些可能要存儲為小數,還有的可能要存儲為日期、字元型,這就是我們 ...


上節回顧

一、數據類型

什麼是數據類型?

  數據類型是指列、存儲過程參數、表達式和局部變數的數據特征,它決定了數據的存儲格式,代表了不同的信息類型。

所謂數據類型,最直接的理解就是我們有些是存儲數字的,而數字當中,我們有時是要存儲為整數,有些可能要存儲為小數,還有的可能要存儲為日期、字元型,這就是我們最直觀、最直接瞭解的數據類型。

在mysql當中,數據類型主要有以下幾類:

整型

浮點型

float最高存儲小數點後7位,一般選擇float,double占用存儲空間較大。因為為了優化,需要選擇最合適的,而不一定是最大的。

日期時間型

各日期類型的開始時間到結束時間:
1、YEAR:1970至2069
2、TIME:-838:59:59至838:59:59
3、DATE:1000-1-1至9999-12-31
4、DATETIME: 1000-1-1 00:00:00至9999-12-31 23:59:59
5、TIMESTAMP存儲範圍:1970-1-1 00:00:00到2037-12-31 23:59:59

日期時間類型在實際中應用較少,因為牽扯到跨時區的問題,如果真的要使用時間類型,一般使用數字的形式表示.

字元型

(1)字元型:char(M) 為定長類型,eg:char(5)當我們在存儲"abc"時,剩餘2位用空格補齊。範圍:0~255
(2)varchar(M)為變長類型,eg:varchar(5)當我們在存儲"abc"時,則varchar中只存abc,不加空格。範圍:0~65535

(3)1Byte == 8bit,11111111 == 2E8 == 255.

(4)enum('value1','value2',·····),只能從給定的enum枚舉中選擇
(5)SET('value1','value2','value3'....)就相當於一個集合,在裡面做排列組合,可以多選裡面的值。

二、數據表操作

數據表(或稱表)是資料庫最重要的組成部分之一,是其他對象的基礎。

我們關係型資料庫,其實就是一張二維表格,這個表格嚴謹點指的就是我們的數據表。這個二維表格,行稱之為記錄,列稱之為欄位。如果我們只創建了資料庫,沒有數據表,那麼我們只有空的架子,並沒有真正存儲數據的地方,如果要存儲數據,必然要設計表。

1、創建數據表(create table)

  可以通過USE命令打開某個資料庫(USE 資料庫名稱);

  顯示當前用戶打開的資料庫:SELECT BATABASE();

  創建數據表:CREATE TABLE [IF NOT EXISTS] table_name(
        column_name data_type,
        .........
        )

比如:

2、查看數據表(show tables)

SHOW TABLES [FROM db_name] [LIKE 'pattern' | WHERE expr]
SHOW TABLES; //查看當前資料庫中的表
SHOW TABLES FROM mysql;//查看資料庫mysql下的表
SELECT DATABASE();//查看當前資料庫

註:1、查看數據表是否存在:SHOW TABLES [FROM db_name] [LIKE 'pattern' | WHERE expr ]
2、FROM db_name 可以查看其它資料庫中的表

3、查看數據表結構(show columns)

4、記錄的插入(insert)與查找(select)

5、空值與非空值

 

禁止為空的欄位一定要賦值。

6、自動編號(auto_increment)

1、自動編號:保證記錄的唯一性
2、類型必須為整型(可以是FLOAT(5,0)等,小數點後必須為0),必須和主鍵PRIMARY KEY組合使用
3、預設情況下,起始值為1,每次的增量為1
預設情況下,起始值為1, 每次增量為1.
CREATE TABLE tb3(
id SMALLINT UNSIGNED AUTO_INCREMENT,
username VARCHAR(30) NOT NULL); //報錯,自動增量欄位必須設置成主鍵

7、初涉主鍵約束(primary key)

auto_increment(自動編號)欄位必須定義為primary key主鍵,但主鍵不一定與auto_increment一起使用。

主鍵自動為NOT NULL,也就是說必須要為主鍵賦值。但如果主鍵選擇了AUTO_INCREMENT,那麼不需要手動賦值。
auto_increment必須和primary key一起使用,反之則沒有這個必要。primary key不允許重覆賦值。 對於給了auto_increment屬性的欄位名,也會給一個unsigned的限制,避免它為負數 自動編號的記錄會從1依次遞增+1 定義主鍵時,可以使用key 也可以使用primary key 使用主鍵約束的欄位 自動會變成 not null約束 定義了主鍵的欄位名的列值不允許相同.

8、初涉唯一約束(unique key)

它與主鍵的區別:主鍵是一張數據表只能有一個,不能為空,但是唯一約束可以存在多個,而且可以存在空值。

註意:唯一約束,可以有空值,但只能有一個空值。

9、初涉預設約束(default)

三、總結

進入指定資料庫 use db_name;
創建資料庫表 create table [if not exists] table_name(columns_name type,columns_name type ..);
查看資料庫表 show tables;(show tables from db_name like table_name)
查看數據表結構 show columns from table_name;
插入記錄 insert [into] table_name [(column_name,...)]values (val,...);
查找記錄 select exp,.. from table_name;
自動編號 auto_increment;auto_increment必須和primary key一起使用
唯一約束 unique key
預設約束 default


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

-Advertisement-
Play Games
更多相關文章
  • 最終解決方式:更換字元集utf8-->utf8mb4 上周有開發人員反饋一個問題:前臺應用抓取微博信息,每天總有幾條數據插入不成功。應用日誌顯示: java.sql.SQLException: Incorrect string value: '\xF0\x9F\x92\xAA",...' for c ...
  • 子查詢 一個select中還包含另一個select,其中最裡面的select語句稱之為子查詢 根據select出現的位置可以將子查詢分為以下幾類: from子查詢 where子查詢 exists子查詢 從select返回的結果,那麼子查詢又可以分為: 標量子查詢 查詢的結果只有一個值。 示例: 需求... ...
  • WHY SQL? 1.SQL is a very-high-level language, in which the programmer is able to avoid specifying a lot of data-manipulation details that would be nec ...
  • 1.彈出錯誤框: 示例代碼: 執行結果: 2.控制台顯示: 示例代碼: 執行結果: ...
  • 如果只導出表的結構(建表語句),不導出表的數據,可用Tools--Export User Objects 選中要導出的表,設置好導出的路徑和各個參數後,點擊Export就OK PS:這種方式只能導出屬於這個用戶的表,其他用戶的表不能導出,建議用命令行導出(exp, imp) 如果想將表結構,表的數據 ...
  • 在知乎上看到這樣一個問題: MySQL 查詢 select * from table where id in (幾百或幾千個 id) 如何提高效率?修改 MySQL 查詢 select * from table where id in (幾百或幾千個 id) 如何提高效率?修改 電商網站,一個商品屬 ...
  • 在保密你的伺服器和數據,防備當前複雜的攻擊,SQL Server有你需要的一切。但在你能有效使用這些安全功能前,你需要理解你面對的威脅和一些基本的安全概念。這篇文章提供了基礎,因此你可以對SQL Server里的安全功能充分利用,不用在面對特定威脅,不能保護你數據的功能上浪費時間。 從讓人眼花繚亂的 ...
  • 1、SELECT基本語句: 2、檢索所有欄位,用"*"替換欄位名,這會導致效率低下 3、去除重覆項,“DISTINCT”作用於所有欄位 4、若檢索結果過多,可限定結果的條數 5、對檢索出的數據進行排序,ASC為升序,也為預設排序方式;DESC為降序。ORDER BY 語句一定是最後一條語句。如果不排 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...