MySQL中的tinyint是一種數據類型,它可以存儲整數值,占用1字節的存儲空間。在實際應用中,因為它只能存儲較小的整數值,所以通常用于表示0或1這種二進制標志位變量。
CREATE TABLE users ( id INT(11) NOT NULL AUTO_INCREMENT, name VARCHAR(255) NOT NULL, is_active TINYINT(1) NOT NULL DEFAULT 0, PRIMARY KEY (id) );
在上面的代碼示例中,我們創建了一個名為“users”的表,其中包含了一個tinyint類型的列is_active。該列只能存儲0或1兩個值,因為我們在定義列時指定了長度為1,超過1的值會被截斷。該列還被設置為默認值為0,因此在插入新行時,如果不顯式指定is_active的值,就會自動設置為0。
除了用于表示二進制標志位之外,tinyint類型還可用于存儲有符號或無符號的整數值。當我們在定義tinyint類型的列時不指定長度時,默認長度為4位,如果指定長度為1,則該列最大存儲值為127。如果要存儲更大的值,我們可以使用smallint、mediumint或int類型。
在查詢數據時,我們可以使用以下語句來篩選is_active值為1的行:
SELECT * FROM users WHERE is_active = 1;
這將返回符合條件的所有行,并且is_active列的值為1。