T-SQL語法基礎

来源:https://www.cnblogs.com/li-learning/archive/2019/03/28/T_SQL_Grammar.html
-Advertisement-
Play Games

一、T-SQL語言的分類 DDL-數據定義語言 create-創建 alter-修改 drop-刪除(針對對象) DML-數據操作語言 Insert-插入 update-更新 delete-刪除(針對對象的內容) DQL-數據查詢語言 select-查詢 DCL-數據控制語言 revoke-撤銷 d ...


一、T-SQL語言的分類

  DDL-數據定義語言

    create-創建

    alter-修改

    drop-刪除(針對對象)

  DML-數據操作語言

    Insert-插入

    update-更新

    delete-刪除(針對對象的內容)

  DQL-數據查詢語言

    select-查詢

  DCL-數據控制語言

    revoke-撤銷

    deny-拒絕

    grant-同意、授權

 

二、語法元素

  批處理元素

    go-語法結束標誌,執行前面的語句或一個完成的處理過程

    exec-調用執行存儲過程

  註釋

    行註釋:--

    塊註釋:/*  */

 

三、數據類型

  整數型

    Bigint:8個位元組,範圍:-263~263-1,精度:19

    Integer:4個位元組,範圍:-231~231-1,精度:10

    Smallint:2個位元組,範圍:-215~215-1,精度:5

    Tinyint:1個位元組,範圍0~255,精度:3

  精確數值型

    Numeric(5,3) -共五位數,其中三位是小數

    Decimal(15,5)-共15位數,其中五位是小數(預設精度為18)

    Decimal(p,s)-p為精度,s為小數位數

    精度為1-9,長度為5個位元組

    精度為10-19,長度為9個位元組

    精度為20-28,長度為13個位元組

    精度為29-38,長度為17個位元組

    註:Numeric與Decimal在是同義詞,可互換使用,建議使用Decimal

  近似數值型

    real等價於float(24)

    float[(n)]其中n為存儲float數值尾數的尾數(以科學記數法表示),因此可以確定精度和存儲大小。如果指定了n,則它必須是介於1和53之間的某個值。n的預設值為53。

 

n 值精度存儲大小
1-24 7 位數 4 個位元組
25-53 15 位數

8 位元組

   貨幣型

    Money 範圍:-263~263-1,精確小數後4位,占8個位元組

    Smallmoney 範圍:-231-231-1,精確小數後4位,占4個位元組

  位型

    bit 表示0或1

    SQL Server 資料庫引擎 可優化 bit 列的存儲。 如果表中的 bit 列為 8 列或更少,則這些列作為 1 個位元組存儲。 如果 bit 列為 9 到 16 列,則這些列作為 2 個位元組存儲,以此類推。

    字元串值 TRUE 和 FALSE 可轉換為 bit 值:TRUE 轉換為 1,FALSE 轉換為 0。

    轉換為 bit 會將任何非零值升為 1。

  日期時間型

    date 範圍:0001-01-01 到 9999-12-31 字元長度:10位 存儲大小:固定3個位元組

    datetime 日期範圍:1753 年 1 月 1 日到 9999 年 12 月 31 日 時間範圍:00:00:00 到 23:59:59.997 字元長度:最低 19 位到最高 23 位 存儲大小:8 位元組

    smalldatetime 日期範圍:1900-01-01 到 2079-06-06 時間範圍:00:00:00 到 23:59:59(2017-07-07 23:59:59 將舍入為2017-07-08 00:00:00) 字元長度:最高19位 存儲大小:固定4個位元組 精度:一分鐘

    time 範圍:00:00:00.0000000 到 23:59:59.9999999 存儲大小:固定5個位元組 精度:100納秒 字元長度:最小 8 位 (hh:mm:ss),最大 16 位 (hh:mm:ss.nnnnnnn)

  字元型

    char 固定長度(以空格填補多餘長度)

    varchar 可變長度

    Nchar “Nuicode”固定長度

    Nvarchar “Nuicode”可變長度

    “Nuicode”國際標準碼:雙位元組模式 如:一個漢字=兩個位元組

  文本型

    text 一個字元占用一個位元組,數據的最大長度為231-1(2,147,483,647)個字元

    Ntext 一個字元占用兩個位元組,數據的最大長度為230-1(1,073,741,823)個字元

  使用數據類型的指導原則

    1.如果列的長度可變,使用某個可變數據類型

    2.要為以後數據的拓展預留空間

    3.精確數值型,建議使用decimal

    4.如果存儲量超過了8000位元組,使用text.如果存儲量小於8000位元組,使用char,可能時,最好使用varchar,原因在於它比text和image有更強的功能

    5.對於貨幣類型來說,使用money數據類型

    6.不要把float和real數據類型作為主鍵,原因在於這些數據類型的值是不精確的,它們不適於在比較中使用

 

四、標識符

  標準標識符

    標準標識符可以包含1到128位字元,包括字母,符號(_、@或#)及數字。標準標識符中不允許有空格。

  限定標識符([ ]/””)

    當對象名字包含空格時

    當保留關鍵字被用作對象名或對象部分的名字時

  標識符的命名規則

    名字儘量短

    儘量使用有意義的名字

    使用簡單的清晰的命名習慣

    使用能區分出對象類型的標識符,尤其是視圖和存儲過程的名字

    保持對象名和用戶名的唯一性

  特殊標識符

    # 局部臨時變數

    ## 臨時變數

    @ 局部變數

    @@ 全局變數

 

五、變數

  變數是可以賦值的SQL語句元素。

  在T-sql中,你可以使用局部變數。

  用戶可以使用decare語句來定義一個局部變數,通過使用set和select語句為這個局部變數賦值,局部變數名前必須帶有@.如果一個變數前有兩個@@符號,那麼它將被作為函數處理。

  例:定義一個字元型變數,賦值為"customer",並顯示變數內容

  declare @tempName varchar(20)

  set @tempName='customer'

  select @tempName

 

六、運算符

  概述

    運算符是進行數學計算、字元操作及欄位、常量和變數比較的符號。

  運算符的種類

    算述運算符:+,-,*,/,%

    比較運算符:=,>,<,>=,<=,<>   

    字元運算符:+

    邏輯運算符:and,or,not用於連接where 子句中的查詢條件

  運算符的優先順序

運算符 優先順序
+(正)-(負)~(按位取反) 1
*、/ 2
+(加),-(減) 3
=,>,<,>=,<=,<> 4
Not 5
And 6
all,between,in,like,or 7
=(賦值) 8

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

-Advertisement-
Play Games
更多相關文章
  • 創建鏈接伺服器註意事項 當我們要跨本地資料庫,訪問另外一個資料庫表中的數據時,本地資料庫中就必須要創建遠程資料庫的DBLINK,通過DBLINNK資料庫可以像訪問本地資料庫一樣訪問遠程資料庫表中的數據。 鏈接伺服器允許訪問針對OLE DB數據源的分散式異構查詢。創建鏈接伺服器後,可以針對此伺服器運行 ...
  • 我們知道,HBASE在創建表的時候,會自動為表分配一個Region,當一個Region過大達到預設的閾值時(預設10GB大小),HBase中該Region將會進行split,分裂為2個Region,以此類推。表在進行split的時候,會耗費大量的資源,頻繁的分區對HBase的性能有巨大的影響。所以, ...
  • ODI(Oracle Data Integrator)是Oracle公司提供的一種數據集成工具,能高效地實現批量數據的抽取、轉換和載入。ODI可以實現當今大多數的主流關係型資料庫(Oracle、DB2、SQL Server、MySQL、SyBase)的集成。ODI提供了圖形化客戶端和agent(代理... ...
  • SolrCloud底層 添加/更新 文檔的過程是怎樣的? 它怎麼確定文檔要發給哪個Shard? 文檔的路由是做什麼的? 有什麼路由策略? 連同一些高效的實踐建議, 統統告訴你~ ...
  • 1. Hadoop安裝包的下載和解壓 基於apache原始廠商:https://archive.apache.org/dist/基於Cloudera廠商的cdh本:http://archiveprimary.cloudera.com/cdh5/cdh/5/,Cloudera有免費版和企業版,企業版只 ...
  • 數據 一對多 多對一 多對多的問題 在關係型資料庫中,通過外鍵將表跟表之間聯繫在了一起。 一對多關係 一個班級有很多學生,外鍵維護在學生的一方,也就是多的一方。(在做頁面設計的時候,需要把兩個表連接到一塊查詢信息) 建立一個student和clazz表 clazz id name 1 一班 2 二班 ...
  • 1.測試聯合索引的最左原則的時候, 發現了5.6版本後的新特性Index Condition Pushdown 2.含義就是存儲引擎層根據索引儘可能的過濾數據,然後在返回給伺服器層根據where其他條件進行過濾 3.比如我有這樣的聯合索引 KEY `name_gid_age_index` (`nam ...
  • 1.int或者tinyint等數值型欄位的存儲範圍已經是固定的,和類型相關2.後面的數字只與顯示有關,並且是在開啟了zerofill前導零填充的前提下 3.顯示的時候,在前面用0補全了 ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...