MySQL用程序代碼建表(1)


一、創建表格代碼格式

create table <表名>
(
<列名> <數據類型及長度> [not null],
<列名> <數據類型及長度>,
...
<列名> <數據類型及長度>
)

例:

#人員基本信息表
create table Info       //建立表名為Info的表格
(
xuhao int primary key auto_increment,    //建列名為xuhao的列,數據類型為整數類型,設為主鍵並且自增長排列
name varchar(50),  //建列名為name的列,數據類型為字符串類型,長度為50個字符
sex bit,         //建列名為sex的列,數據類型為布爾型
minzu varchar(50),    //建列名為minzu的列,數據類型為字符串類型,長度為50個字符
foreign key(minzu) references Nation(code),   //對於minzu列建立外鍵,用表名為Nation的code列為約束
#minzu varchar(50) references Nation(code),  //建外鍵的另一種格式,但是運行后在外鍵設置界面中不顯示
shengri datetime,  //建列名為shengri的列,數據類型為日期時間類型
height double(6,2) //建列名為height的列,數據類型為小數類型,總長度為6,小數點后留2位
);

命令語句:

primary key 主鍵
not null 非空
foreign key(子表列名) references <父表名>(父表列名) 外鍵
auto_increment 自增長

注意:所有符號必須是英文狀態下的
每個表創建完之后加分號
表里面的最后一列寫完之后不要加逗號

二、刪除表格代碼格式

drop table <表名>

 

三、表格內數據的操作

大致可分為增、刪、改、查  CRUD

1.添加數據
insert into <表名>[(列1,列2...)] values (<‘值1’>[,‘值2’...])
注意:
(1)列與值要匹配(數量,類型,排序)
(2)列可以省掉,但值必須與表中的總列數和列的次序完全對應

(3)部分數據添加時自增長列(即主鍵列)不能省,不給明確值的要給自增列賦值‘'
(4)布爾型數據不用‘’用true/false代替,數字類型也不用‘’可直接寫數字

例:

insert into Info(xuhao,name,minzu,shengri)values(‘’,‘張三’,‘n003’,‘1992-2-2’)  //在Info表中添加姓名為張三,民族為n003,生日為1992-2-2 其中‘’為自增長列表示順序增加,以其上一條內容的xuhao值向后自動增加,其余列為null

2.刪除數據

delete from Brand    //刪除所有數據

delete from car where code='c001'   //刪除表car中code列為c001的行的數據
delete from car where brand='b001' or brand='b004'  // 刪除表car中brand列為b001和b004的行的數據
delete from car where brand='b001' || brand='b004'  // 刪除表car中brand列為b001和b004的行的數據
delete from car where brand='b007' && price>50      //刪除表car中brand列為b007並且price列大於50的行的數據
delete from car where brand='b007' and price>50    //刪除表car中brand列為b007並且price列大於50的行的數據

3.更改數據

update <表名> set <列=值>[,列=值...] where .....

例:
update info set sex='1' where code='p003'    // 將info表中code列為p003的行的sex列的數據改為1
update info set sex='0',nation='n004',birthday='1999-9-9' where code='p001'    //將info表中code列為p001的行的sex列改為0,nation列改為n004,birthday列改                                                                                                                       為1999-9-9
update car set price=price * 0.9 where price > 30   //將car表中price列大於30的price列的數據乘以0.9
update car set price =price * 0.95 where (brand='b006' || brand='b005')&&price>30   // 將car表中brand列為b006和b005並且price列大於30的price列的數據乘以                                                                                                                                0.95

4.查找數據

select * from 表名
select 列名1,列名2... from 表名 --投影
select * from 表名 where 條件 --篩選

(1)條件查詢
select * from car where code='c001';   // 從car表中查找code列為c001的行的數據
select * from car where code != 'c001';  // 從car表中查找code列不為c001的行的數據
select * from car where price > 30;    //從car表中查找price列大於30的行的數據
(2)范圍查詢
select * from car where price >=30 && price <=50;  //從car表中查找price列大於等於30並且小於等於50的行的數據 (&&=and)
select * from car where price between 30 and 50     //從car表中查找price列大於等於30並且小於等於50的行的數據
select * from car where brand='b002' || brand='b004' || brand='b006'  //從car表中查找brand列為b002、b004、b006的行的數據(||=or)

(3)分類查詢
select * from car where brand in ('b002','b004','b006')     //從car表中查找brand列為b002、b004、b006的行的數據

select * from car where brand not in ('b002','b004','b006')     //從car表中查找brand列不為b002、b004、b006的行的數據

(4)模糊查詢
select * from car where name like '寶馬%'    //從car表中查找以“寶馬”開頭的所有數據    %表示任意多個任意字符
select * from car where name like '%5%'    // 從car表中查找中間包含“5”的所有數據
select * from car where name like '%型'      // 從car表中查找以“型” 結尾的所有數據
select * from car where name like '__5%'    // 從car表中查找第三位是“5”的所有數據    _ (下划線)表示一個任意字符

(5)排序
select * from 表名 order by 列名 [ASC/DESC],列名[asc/desc]....

select * from car order by price desc     // 將car表的數據按照price列數據降序排列
select * from car order by brand desc,price asc   // 將car表的數據按照brand列數據降序排列,price列數據升序排列


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM