C# 數據操作系列 - 1. SQL基礎操作

来源:https://www.cnblogs.com/c7jie/archive/2020/05/10/12862161.html
-Advertisement-
Play Games

0.前言 前篇介紹了一些資料庫的基本概念和以及一些常見的資料庫,讓我們對資料庫有了一個初步的認識。這一篇我們將繼續為C 數據操作的基礎填上一個空白 SQL語句。 SQL(Structured Query Language,結構化查詢語言)是一種特定的編程語言,用於管理資料庫系統,操作數據甚至編寫一些 ...


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


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 視頻:https://www.bilibili.com/video/BV15x411x7WN?p=5 新建Devexpress Winform BlankApplication。 添加GridControl,Change View為LayoutView。 添加LayoutViewColumn,設置C ...
  • 一、在Jenkins中安裝Nunit插件進入jenkins的插件管理模塊,下載Nunit插件。此步驟不做截圖說明二、引用nunit.console的nuget包通過項目引用Nunit.console包 然後可以packages\NUnit.ConsoleRunner.3.11.1\tools文件夾查 ...
  • 一、發佈配置差異配置:編譯內容編譯目標NetWorkClient/KJ90NetClient.csproj編譯命令/t:build/p:Configuration=Release /p:OutputPath=../UploadRelease運行外部程式二、配置jenkins啟動外部程式不報錯通過參數... ...
  • 項目模板簡介 眾所周知,在我們使用VS新建項目時,都需要選擇一個項目模板,如下圖: 我們選擇完項目模板進行創建,創建完成之後,可以發現項目中已經包含了一些基礎的文件。例如MVC: 可以看到,MVC項目下,這麼多的文件、類都給我們自動生成了,我們並不需要敲任何代碼。 所以,項目模板,就是在我們創建新項 ...
  • 一.介紹ClosedXML.Report ClosedXML.Report開源報表 支持net4.0+。 github:https://github.com/ClosedXML/ClosedXML.Report github項目下載慢參考:https://blog.csdn.net/czjnoe/a ...
  • 第四講:https://www.bilibili.com/video/BV15x411x7WN?p=4 添加GridControl,一個GridControl可以對應多個展示數據View,預設會有一個GridView。設置ShowGroupPanel=false。 預設GridView,運行設計器。 ...
  • 先上截圖 修正2 源代碼 修正: 應該將SetTime方法修改為,行號為207行開始修改 var nk = Day_of_week(year, month, 1); if (nk == 0) nk = 7; for (var i = 0; i < nk-1; i++) { Time.Add(new ...
  • 據老一輩的程式員說開發三維程式門檻很高,需要學若幹年才能入門,自從遇上AnyCAD三維控制項後,開發三維應用變的簡單了。當結合nuget後,一切更簡單了。 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...