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