0.前言
前篇介紹了一些資料庫的基本概念和以及一些常見的資料庫,讓我們對資料庫有了一個初步的認識,這一篇我們將繼續為C#資料操作的基礎填上一個空白-SQL陳述句,
SQL(Structured Query Language,結構化查詢語言)是一種特定的編程語言,用于管理資料庫系統,操作資料甚至撰寫一些程式,
當然,一方面因為時間問題,一方面因為各大資料庫的區別(當然了,還有就是個人對SQL研究并不是那么深)所以這一篇就從SQL的基本操作入手,帶領大家一起看看SQL的世界,
1. SQL的分類
在SQL的世界里,被分割為兩個部分:DML(Data Manipulation Language 資料操縱語言)、DDL(Database Definition Language 資料定義語言),當然,也有很多其他的分法,這里參照了機械工業出版社出版的《計算機科學叢書- 資料庫系統概念》,
1.1 DML
資料操縱語言,用戶可以憑此來訪問或者操縱那些被結構化存盤起來的資料,DML提供了以下功能:
- 對存盤在資料庫的資料進行檢索(select)
- 在資料庫中添加新的資料(insert)
- 修改資料庫中的資料(update)
- 洗掉資料庫中的某些資料(delete)
簡單的概括起來就是增刪改查,對于開發而言這是一項枯燥乏味的作業,當然也是每個程式必不可少的作業,如果你見到這個詞:crud,不要詫異,這是開發對增刪改查的一種縮寫(create,read,update,delete),
在技術的演變程序中,為了更快更好的增刪改查,有一些大牛開發出了一系列的ORM框架,比如C#里最出名的EntityFramework、與Hibernate同源的NHibernate等等,
1.2 DDL
資料定義語言,用戶可以用來創建資料庫、修改資料庫屬性、洗掉資料庫,新建表、視圖,修改表、視圖,洗掉表、視圖等,與DML不同的是,DDL操作的物件從資料轉變成了承載資料的物體或者與操作資料的物體,
還有與DML不同的一點是,DDL更多的會使用 create、alter、drop等關鍵字(分別用來 創建、修改、銷毀),
1.3 方言
如今的城市人們來自五湖四海,有的人用普通話,有的人還是一口流利的家鄉話,與之相同的就是在資料庫這個江湖里,各大門派都在標準SQL里添加了自己的東西,讓SQL成了一個操持著五湖四海的方言的大家族,比如說微軟的Transcat-SQL和PL/SQL,
2. 一些簡單操作
這里先簡單介紹一下通用SQL下的操作:
2.1 創建資料庫
create database test;
這是一個簡單的創建資料庫的SQL陳述句,這是標準SQL的一部分,效果就是創建一個名字為test的資料庫,字符集等屬性是系統的默認值,
當然,在SQL Server里可以通過以下方式指定字符集:
create database 資料庫名 DEFAULT CHARACTER SET gbk COLLATE gbk_chinese_ci; -- 使用gbk
CREATE DATABASE 資料庫名 DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci; -- 使用utf8
這是在開發程序中最常用的創建資料庫方式,
2.2 創建表
資料表是資料庫里最重要的一個物體,我們大概演示一下如何通過sql陳述句創建一個表:
create table demo
(
[key] int identity primary key ,
[name] varchar(20)
)
go
SQL 創建表的格式如下:
create table <表名>
(
[屬性名] <型別> [params...配置]
)
如果有第二個屬性,則在第一個之后添加一個逗號,然后繼續按照格式宣告,
其中 屬性名和型別是必須的,配置則可有可無,
常見配置項:
- identity 表示該列是個自增列,一般是起始1,增長步長為1
- primary key 表示該列是主鍵列,只能有一個主鍵
- not null 表示該欄位非空,如果是空值進來則會報錯
- unique 表示該欄位的值不能出現重復
而資料型別則因為資料庫不同會有一些細微的差別,所以這里就不錯過多介紹了,
2.3 查詢
一個簡單的查詢:
select * from demo;
表示查詢該表的所有陣列,
然后更進一步,可以限制查詢條件:
select * from demo where <條件>;
注意一下這里的條件里的等值判斷用的是一個等號,而不像開發語言里用的是雙等號,
這時候發現我們用不了那么多的欄位,然后篩選出要顯示的欄位:
select <欄位01>,<欄位02>,<欄位03> from [表名] where <條件>
這里簡單介紹一下查詢,當然還有很多沒有一一介紹,在后續的章節會把這部分補齊的,
2.4 添加資料
在查詢之前,我們得先保證資料表里有資料,所以我們看看如何插入資料吧,
插入單條記錄:
insert into [表名](<欄位1>,<欄位2>,<欄位3>) values('值1','值2','值3')
在表名后面跟括號,括號內寫入要插入值的欄位,然后values關鍵字后面用括號包裹起來的一組值便是要插入的值,插入值要與欄位名一一對應,
如果要插入多條記錄呢?
insert into [表名](<欄位1>,<欄位2>,<欄位3>) values('值1','值2','值3'),('值1','值2','值3')
如果需要插入多條的話,將資料用括號包裹起來,然后依次跟在values后面,
2.5 修改資料
當我們發現插入的資料有問題的時候或者因為業務的進行,資料庫表里的資料需要更新,這時候我們可以參照以下方式寫自己的sql:
update [表名]
set <欄位1> = <值1>
如果需要更新多個欄位,可以在更新欄位后面添加一個逗號,然后跟在后面,簡單實體:
update AdditionalService
set storeid = 1 , name = '23'
目前所以的更新都是全表更新,當然我們一樣可以使用 where來限制,
2.6 洗掉資料
洗掉資料的關鍵字是delete,所以洗掉的寫法是:
delete [表名]
where <條件>
如果不設定where 條件,則洗掉的是全表資料,
2.7 洗掉表
洗掉表的操作:
drop table [表名]
這個操作會把表結構和表里的資料都洗掉,
3.總結
這一篇大概介紹了SQL的基本用法,開發程序中的SQL基本夠用了,后續會隨著文章內容逐步填補未介紹的部分,
更多內容煩請關注我的博客《高先生小屋》

轉載請註明出處,本文鏈接:https://www.uj5u.com/net/40632.html
標籤:C#
上一篇:C# 多執行緒猜想
