【SQL.基礎(chǔ)構(gòu)建-第四節(jié)(4/4)】

--?? ?? Tips:數(shù)據(jù)更新

--一抄沮、插入數(shù)據(jù)

--1.INSERT 語句的基本語法

--語法:

--INSERT INTO <表名>(列1, 列2, ...) VALUES (值1, 值2, ...)

--示例

INSERT INTO dbo.conbio

( conbio_id ,

conbio_name ,

conbio_varieties ,

conbio_price1 ,

conbio_price2 ,

conbio_date

)

VALUES? ( '0011' , -- conbio_id - char(4)

'T 恤衫' , -- conbio_name - varchar(100)

'衣服' , -- conbio_varieties - varchar(32)

1000 , -- conbio_price1 - int

500 , -- conbio_price2 - int

GETDATE()? -- conbio_date - date

);

------------------

select * from conbio?? ??? ?--查詢表名為conbio的表.

--------------------------------------

--(1)列名和值用逗號(hào)隔開蝙叛,分別放在括號(hào)里辙诞,這種形式稱為清單惧浴。

( shohin_id ,

shohin_mei ,

shohin_bunrui ,

hanbai_tanka ,

shiire_tanka ,

torokubi

)

--列清單?? ??? ??? ?--字段

------------------

( '0011' , -- shohin_id - char(4)

'T 恤衫' , -- shohin_mei - varchar(100)

'衣服' , -- shohin_bunrui - varchar(32)

1000 , -- hanbai_tanka - int

500 , -- shiire_tanka - int

GETDATE()? -- torokubi - date

)

--值清單?? ??? ??? ?--記錄

------------------

INSERT INTO dbo.conbio

( conbio_id ,

conbio_name ,

conbio_varieties ,

conbio_price1 ,

conbio_price2 ,

conbio_date

)

VALUES? ( '0014' , -- conbio_id - char(4)

'T 恤衫' , -- conbio_name - varchar(100)

'衣服' , -- conbio_varieties - varchar(32)

1000 , -- conbio_price1 - int

500 , -- conbio_price2 - int

GETDATE()? -- conbio_date - date

),

( '0015' , -- conbio_id - char(4)

'T 恤衫' , -- conbio_name - varchar(100)

'衣服' , -- conbio_varieties - varchar(32)

1000 , -- conbio_price1 - int

500 , -- conbio_price2 - int

GETDATE()? -- conbio_date - date

);

--------------------------------------

--3.插入 NULL 值

INSERT INTO dbo.conbio

VALUES? ( '0016' , -- conbio_id - char(4)

'T 恤衫' , -- conbio_name - varchar(100)

'衣服' , -- conbio_varieties - varchar(32)

1000 , -- conbio_price1 - int

NULL , -- conbio_price2 - int

GETDATE()? -- conbio_date - date

);

--【備注】插入 NULL 值的列不能設(shè)置為 NOT NULL 約束瑟蜈。

--------------------------------------

select * from conbio?? ?--查詢表

--------------------------------------

----添加列

select * from??? conbio;

alter table Conbio add conbio_name_test001?? varchar(100);

--------------------------------------

----刪除列

ALTER TABLE conbio DROP COLUMN conbio_name_test001;

--------------------------------------

--4.插入默認(rèn)值

--示例:創(chuàng)建表時(shí)設(shè)置默認(rèn)值

CREATE TABLE ConbioIns

(

id CHAR(4) NOT NULL,

num INT DEFAULT 0??? --DEFAULT 默認(rèn)約束

)

-- select * from conbioins?? ??? ?查表

--示例:INSERT 時(shí)顯示插入默認(rèn)值

INSERT INTO dbo.conbioins

( id, num )

VALUES? ( '002', -- id - char(4)

DEFAULT? -- num - int

)

--示例:INSERT 隱式插入默認(rèn)值

INSERT INTO dbo.conbioins( id )

VALUES? ('003')

--【備注】建議使用顯示的方式插入值塞俱。如果插入的時(shí)候隱式省略了列名姐帚,并且該列沒有指定默認(rèn)值的時(shí)候,

--該列的值會(huì)被設(shè)定為 NULL(如果省略的列設(shè)置了 NOT NULL 約束的話障涯,執(zhí)行會(huì)報(bào)錯(cuò))罐旗。

--【總結(jié)】省略 INSERT 語句的列名,就會(huì)自動(dòng)設(shè)定該列的默認(rèn)值(沒有默認(rèn)值時(shí)會(huì)設(shè)定為 NULL)唯蝶。

--------------------------------------

--5.從其它表復(fù)制數(shù)據(jù)

--語法

--INSERT ...

--SELECT ...

--示例

INSERT dbo.conbioins

( id, num )

SELECT conbio_id, conbio_price2

FROM dbo.conbio

--示例

INSERT INTO dbo.conbioins

( id, num )

SELECT id=1, num =2;

--示例

INSERT INTO dbo.conbioins

( id, num )

SELECT 1, 2;

-- select * from conbioins?? ??? ?查表

--【備注】INSERT 語句中的 SELECT 語句中九秀,可以使用 WHERE 子句或者 GROUP BY 子句等任何 SQL 語法。(但使用 ORDER BY 子句并不會(huì)產(chǎn)生任何效果粘我。)

--------------------------------------

--?? ?二颤霎、刪除數(shù)據(jù)

--  1.2 種 刪除數(shù)據(jù)的方法:

--(1)DROP TABLE 語句:刪除表

--(2)DELETE 語句:刪除表的數(shù)據(jù)

--語法

--DELETE FROM <表名>;

--示例

DELETE FROM dbo.conbioins;?? ??? ?--此表數(shù)據(jù)刪除為空所有

--【備注】DELETE 語句刪除的對(duì)象是記錄(行),不是表和列涂滴。

--------------------------------------

--2.指定刪除對(duì)象的 DELETE 語句

--語法

--DELETE FROM <表名>

--WHERE <條件>;

--示例

DELETE FROM dbo.conbio

WHERE conbio_price1 >= 1000;?? ??? ?--條件刪除記錄行

--【備注】可以通過 WHERE 子句指定對(duì)象條件來刪除部分?jǐn)?shù)據(jù)友酱。

--【備注】DELETE 語句中不能使用 GROUP BY、HAVING 和 ORDER BY 三類子句柔纵。

--【備注】如果要?jiǎng)h除表全部數(shù)據(jù)時(shí)請(qǐng)使用 TRUNCATE <表名>缔杉,它比 DELETE 子句更高效。

--select * from conbio? --查表

--------------------------------------

--三搁料、更新數(shù)據(jù)

--1.UPDATE 子句的基本語法

--語法

--UPDATE <表名>

--??? SET <列名> = <表達(dá)式>

--2.指定條件的 UPDATE 語句

--語法

--UPDATE <表名>

--??? SET <列名> = <表達(dá)式>

--WHERE <條件>;

--示例

UPDATE dbo.conbio

SET conbio_price2 = conbio_price2 * 10

WHERE conbio_varieties = '廚房用具';

--3或详、使用 NULL 進(jìn)行更新

--示例

UPDATE dbo.conbio

SET conbio_date = NULL

WHERE conbio_id = '008';

--【備注】只有未設(shè)置 NOT NULL 約束和主鍵約束的列才可以清空為 NULL。

--------------------------------------

--4.多列更新

--示例

UPDATE dbo.conbio

SET conbio_price1 = conbio_price1 * 10,?? ??? ?--逗號(hào)分割

conbio_price2 = conbio_price2 / 2

WHERE conbio_varieties = '廚房用具'

--------------------------------------

--四郭计、事務(wù)

--1.事務(wù):需要在同一個(gè)處理單元中執(zhí)行的一系列更新處理的集合霸琴。

--2.創(chuàng)建事務(wù):

--語法

--事務(wù)開始語句

--??? DML 語句①;

--??? DML 語句②;

--??? ...

--事務(wù)結(jié)束語句(COMMIT 或 ROLLBACK);

--(1)COMMIT - 提交處理:提交事務(wù)包含的全部更新處理的結(jié)束指令。一旦提交昭伸,無法恢復(fù)到事務(wù)開始前的狀態(tài)梧乘。

--(2)ROLLBACK - 取消處理:取消事務(wù)包含的全部更新處理的結(jié)束指令。一旦回滾,數(shù)據(jù)庫就會(huì)回復(fù)到事務(wù)開始之前的狀態(tài)选调。

------------------

--示例

begin transaction;

UPDATE dbo.conbio

SET conbio_price1 = conbio_price1 - 1000

WHERE conbio_name = '叉子';

UPDATE dbo.conbio

SET conbio_price1 = conbio_price1 + 1000

WHERE conbio_name = '叉子';

DELETE FROM dbo.conbio WHERE conbio_id = '6';

rollback;?? ??? ??? ?-- COMMIT 承諾

--------------------------------------

--3.ACID 特性

--   〖泄(1)原子性(Atomicity):在事務(wù)結(jié)束時(shí),其中包含的更新處理要么全部執(zhí)行仁堪,要么完全不執(zhí)行哮洽。

--    (2)一致性(Consistency):事務(wù)中包含的處理弦聂,要滿足數(shù)據(jù)庫提前設(shè)置的約束鸟辅,也稱完整性。

--   ≥汉(3)隔離性(lsolation):保證不同事務(wù)之前互不干擾的特性剔桨。

--   『暝痢(4)持久性(Durability):事務(wù)一旦結(jié)束诽凌,DBMS 會(huì)保證該時(shí)點(diǎn)的數(shù)據(jù)狀態(tài)得以保存的特性窄瘟,也稱耐久性。

--------------------------------------

--歡迎關(guān)注個(gè)人公眾號(hào):Zkcops

由:zkcops 撰寫(希望能對(duì)你有所幫助欺冀,轉(zhuǎn)載注明出處!)

--------------------------------------

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末萨脑,一起剝皮案震驚了整個(gè)濱河市隐轩,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌渤早,老刑警劉巖职车,帶你破解...
    沈念sama閱讀 207,113評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異鹊杖,居然都是意外死亡悴灵,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,644評(píng)論 2 381
  • 文/潘曉璐 我一進(jìn)店門骂蓖,熙熙樓的掌柜王于貴愁眉苦臉地迎上來积瞒,“玉大人,你說我怎么就攤上這事登下∶?祝” “怎么了?”我有些...
    開封第一講書人閱讀 153,340評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵被芳,是天一觀的道長(zhǎng)缰贝。 經(jīng)常有香客問我,道長(zhǎng)畔濒,這世上最難降的妖魔是什么剩晴? 我笑而不...
    開封第一講書人閱讀 55,449評(píng)論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮侵状,結(jié)果婚禮上李破,老公的妹妹穿的比我還像新娘宠哄。我一直安慰自己,他們只是感情好嗤攻,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,445評(píng)論 5 374
  • 文/花漫 我一把揭開白布毛嫉。 她就那樣靜靜地躺著,像睡著了一般妇菱。 火紅的嫁衣襯著肌膚如雪承粤。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,166評(píng)論 1 284
  • 那天闯团,我揣著相機(jī)與錄音辛臊,去河邊找鬼。 笑死房交,一個(gè)胖子當(dāng)著我的面吹牛彻舰,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播候味,決...
    沈念sama閱讀 38,442評(píng)論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼刃唤,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了白群?” 一聲冷哼從身側(cè)響起尚胞,我...
    開封第一講書人閱讀 37,105評(píng)論 0 261
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎帜慢,沒想到半個(gè)月后笼裳,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,601評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡粱玲,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,066評(píng)論 2 325
  • 正文 我和宋清朗相戀三年躬柬,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片抽减。...
    茶點(diǎn)故事閱讀 38,161評(píng)論 1 334
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡楔脯,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出胯甩,到底是詐尸還是另有隱情昧廷,我是刑警寧澤,帶...
    沈念sama閱讀 33,792評(píng)論 4 323
  • 正文 年R本政府宣布偎箫,位于F島的核電站木柬,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏淹办。R本人自食惡果不足惜眉枕,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,351評(píng)論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧速挑,春花似錦谤牡、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,352評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至腊满,卻和暖如春套么,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背碳蛋。 一陣腳步聲響...
    開封第一講書人閱讀 31,584評(píng)論 1 261
  • 我被黑心中介騙來泰國打工胚泌, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人肃弟。 一個(gè)月前我還...
    沈念sama閱讀 45,618評(píng)論 2 355
  • 正文 我出身青樓玷室,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國和親笤受。 傳聞我的和親對(duì)象是個(gè)殘疾皇子穷缤,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,916評(píng)論 2 344

推薦閱讀更多精彩內(nèi)容