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 創建數據庫

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基本夠用了。后續會隨着文章內容逐步填補未介紹的部分。

更多內容煩請關注我的博客《高先生小屋》

file


免責聲明!

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



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