1. 程式人生 > >C# 資料操作系列 - 1. SQL基礎操作

C# 資料操作系列 - 1. SQL基礎操作

# 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 建立資料庫 ```sql create database test; ``` 這是一個簡單的建立資料庫的SQL語句,這是標準SQL的一部分。效果就是建立一個名字為test的資料庫,字符集等屬性是系統的預設值。 當然,在SQL Server裡可以通過以下方式指定字符集: ```sql 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語句建立一個表: ```sql create table demo ( [key] int identity primary key , [name] varchar(20) ) go ``` SQL 建立表的格式如下: ```sql create table <表名> ( [屬性名] <型別> [params...配置] ) ``` 如果有第二個屬性,則在第一個之後新增一個逗號,然後繼續按照格式宣告。 其中 屬性名和型別是必須的,配置則可有可無。 常見配置項: - identity 表示該列是個自增列,一般是起始1,增長步長為1 - primary key 表示該列是主鍵列,只能有一個主鍵 - not null 表示該欄位非空,如果是空值進來則會報錯 - unique 表示該欄位的值不能出現重複 而資料型別則因為資料庫不同會有一些細微的差別,所以這裡就不錯過多介紹了。 ## 2.3 查詢 一個簡單的查詢: ```sq select * from demo; ``` 表示查詢該表的所有陣列。 然後更進一步,可以限制查詢條件: ```sql select * from demo where <條件>; ``` 注意一下這裡的條件裡的等值判斷用的是一個等號,而不像開發語言裡用的是雙等號。 這時候發現我們用不了那麼多的欄位,然後篩選出要顯示的欄位: ```sql select <欄位01>,<欄位02>,<欄位03> from [表名] where <條件> ``` 這裡簡單介紹一下查詢,當然還有很多沒有一一介紹,在後續的章節會把這部分補齊的。 ## 2.4 新增資料 在查詢之前,我們得先保證資料表裡有資料,所以我們看看如何插入資料吧。 插入單條記錄: ```sql insert into [表名](<欄位1>,<欄位2>,<欄位3>) values('值1','值2','值3') ``` 在表名後面跟括號,括號內寫入要插入值的欄位,然後values關鍵字後面用括號包裹起來的一組值便是要插入的值。插入值要與欄位名一一對應。 如果要插入多條記錄呢? ```sql insert into [表名](<欄位1>,<欄位2>,<欄位3>) values('值1','值2','值3'),('值1','值2','值3') ``` 如果需要插入多條的話,將資料用括號包裹起來,然後依次跟在values後面。 ## 2.5 修改資料 當我們發現插入的資料有問題的時候或者因為業務的進行,資料庫表裡的資料需要更新,這時候我們可以參照以下方式寫自己的sql: ```sql update [表名] set <欄位1> = <值1> ``` 如果需要更新多個欄位,可以在更新欄位後面新增一個逗號,然後跟在後面,簡單例項: ```sql update AdditionalService set storeid = 1 , name = '23' ``` 目前所以的更新都是全表更新,當然我們一樣可以使用 where來限制。 ## 2.6 刪除資料 刪除資料的關鍵字是delete,所以刪除的寫法是: ```sql delete [表名] where <條件> ``` 如果不設定where 條件,則刪除的是全表資料。 ## 2.7 刪除表 刪除表的操作: ```sql drop table [表名] ``` 這個操作會把表結構和表裡的資料都刪除。 # 3.總結 這一篇大概介紹了SQL的基本用法,開發過程中的SQL基本夠用了。後續會隨著文章內容逐步填補未介紹的部分。 > 更多內容煩請關注[我的部落格《高先生小屋》](https://www.attachie.club) ![file](https://img2020.cnblogs.com/other/1266612/202005/1266612-20200510090629132-1077086