SQL基本操作

来源:https://www.cnblogs.com/xjmlove/archive/2018/05/20/9062685.html
-Advertisement-
Play Games

系統資料庫: 1、master:用於記錄所有SQL server系統級別的信息,比如說登錄的信息,系統設置信息。如果他沒了。你的SQL server就掛了。 2、model:模型的意思,就像模板一樣。創建資料庫都是繼承model。如果你在該資料庫下創建一張表,以後每創建新資料庫,就已經有了model ...


系統資料庫

    1、master:用於記錄所有SQL server系統級別的信息,比如說登錄的信息,系統設置信息。如果他沒了。你的SQL server就掛了。

    2、model:模型的意思,就像模板一樣。創建資料庫都是繼承model。如果你在該資料庫下創建一張表,以後每創建新資料庫,就已經有了model的表。

    3、msdb:和master一樣記錄信息,不同的是它記錄任務調動,事件處理,數據備份及恢復,報警和異常的信息。

    4、tempdb:臨時資料庫,它為所有臨時表,臨時存儲過程提供存儲空間

註意:以上四個系統資料庫,別去刪,刪了有大大小小的問題。

數據類型:

    1數值型:

          整型:int  smallint  bigint  tinyint

          浮點型:float  real

          貨幣型:money

    2布爾型(bit):

         True

         False

    3二進位型

         binary

         varbinary

         image

    4文本數據類型

        char    固定長度

        vachar  可變長度

        nvarchar

        nchar  

        text    長文本信息

        ntext   可變長度的長文本

        datetime 日期和時間

新建資料庫:

    1資料庫文件  :主數據文件和副數據文件

    2日誌文件:一個或多個

    3create database 名稱

重命名資料庫:exec sp_renamedb new,old

刪除資料庫:drop database 名稱1,名稱2

新建資料庫:

    create database test(資料庫文件名)

    on

    (

    name=test_data(主數據文件),

    filename = 'D:\ProgramFiles\SQL\data\test_data.mdf',

    size=6(初始化大小),

    maxsize=12,

    filegrowth(增長率)=10%

    )

    log on

    (

    name=test_log(日誌文件),

    filename='D:\ProgramFiles\SQL\data\test_log.ldf',

    size=1,

    maxsize=8,

    filegrowth=10%

    )

創建表:

  create table 教師表

  (

  教師編號 int identity(1,1) primary key,

  教師姓名 varchar(20) not null,

  教師年齡 int,

  教師工資 money,

  獎金 money,

  總收入 money,

  合作院校 varchar

  )

  說明:

    identity:表示自增長,通常為ID賦值

    primary key:主鍵

    not null:不為空

  註意:每個欄位後面的逗號別忘了

查詢表:

    select * from 教師表

    select 獎金,總收入 from 教師表

刪除表:

    use test--切換到該表所在的資料庫下,如果已經在,就不用切換

    drop table 教室表--刪除整個表

刪除表,但不刪除表結構,只清空數據;

    Truncate table 教師表

重命名錶:

    exec sp_rename 教師表,教師表1

新增欄位:

    alter table 教師表

    add Email varchar(60) default ''

修改欄位:

    alter table 教師表

    alter column 教師薪資 int

刪除欄位:

    alter table 教師表

    drop column 家庭住址

新增數據:

    insert into 教師表(教師年齡,教師職稱,教師薪資,課程)

    values(19,'微微',100000,'java')

查詢數據:

    select * from 教師表 where 教師薪資<10000

 

    select * from 教師表 where 教師薪資 in(5555,6666,9999)

    select * from 教師表 where 姓名  not in(select 班主任 from 課程表)

    select 姓名,教師薪資+獎金 as 總收入 from 教師表

 

    select * from 課程表 where 合作學校 like '%馬%'

    select * from 課程表 where 合作學校 like '黑%'

 

     select top 4 * from 課程表

    select top 20 percent * from 教師表

 

    select * from 課程表1 intersec select * from 課程表2   集合交

 

    select * from 教師表,課程表1 where 教師表.姓名=課程表1.班主任

    select * from 教師表,課程表1 where 姓名=班主任     去尾碼

    排序:

        select * from 教師表 order by 年齡 --預設升序,倒序desc

        select * from 教師表 order by 年齡,教師薪資

    去重:

        select distinct 姓名 from 教師表

    統計求和:

        select COUNT(*) as 行數 from 教師表

        select COUNT(姓名) from 教師表

    平均:

        select avg(教師薪資) from 教師表

    最大和最小:

        select max(教師薪資) from 教師表

更新數據:

    update 教師表 set 教師年齡=28,教師薪資=7777 where 教師編號=4

    update 教師表 set 姓名='蓮花中學之'+姓名

刪除數據:

    delete from 教師表 where 教師編號=7

 

約束:

1、unique:唯一約束,一個表可以有多個約束,但primary 約束只有一個

 

2、Primary key:約束唯一標識資料庫中的每條記錄,主鍵必須包含唯一值,不能包含null值,有且只有一個主鍵。

 

3、Foreign key:兩個表的約束

 

4、check 約束:如果對單個列定義check約束,那麼該列值運行特定的值。

                  如果對一個表定義check約束,那麼此約束會在特定的列中對值          進行限制。

5、default:預設值

alter table userIofo

add constraint PK_userId primary key(userId),

    constraint CK_userPwd check(len(userPwd)>6),

    constraint Ck_Gender check(Gender=0 or Gender=1),

    constraint DF_Gender default(0) for gender,

    constraint CK_Email check(Email like '%@%')

--[1]外鍵約束時註意類型,長度必須與引用的主鍵列的類型,長度一致

--[2]外鍵約束時註意引用表中必須要有主鍵列

--[3]exec sp_helpconstraint 表名稱


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

-Advertisement-
Play Games
更多相關文章
  • 0.安裝環境和版本 Ubuntu16,hadoop版本是2.7.2 ,選擇Hive版本為 hive-2.1.17 1. Hive安裝包下載 地址: https://mirrors.tuna.tsinghua.edu.cn/apache/hive/ 2.上傳到伺服器後解壓 3.配置 添加以下內容: 保 ...
  • 創建分散式事務處理DTC群集服務 在hsr3 ip 49上繼續 \ 輸入一個沒有衝突的ip地址用作SQL-CL的DTC解析地址:192.168.2.110,通過檢測後會在DNS伺服器中自動創建一條記錄 選擇日誌盤此時是捲(M) 註意DTC是放在日誌盤上,也是後面的M盤 此時我們來看看各系統的分配 H ...
  • 測試故障轉移群集報告 在SQL-CL01(hsr 50)進行故障轉移群集的創建,如圖下圖所示,在SQL-CL01和SQL-CL02的“伺服器管理”中右鍵點擊“功能”,選擇“添加功能 勾選故障轉移群集 (註意:操作故障轉移群集使用域登錄進去) 同樣也在SQL-CL02(hsr 51)上安裝故障轉移群集 ...
  • 1、資料庫的好處 (1)實現數據持久化 (2)使用完整的管理系統統一管理,可以實現結構化查詢 2、資料庫的概念 (1)DB:資料庫(database),存儲數據的倉庫,它保存了一系列有組織的數據。 (2)DBMS:資料庫管理系統(Database Management System),又稱為資料庫軟 ...
  • 作者的電腦是10.13.3,些許配置偏差請自行略過 本文是學習探討途徑,請勿濫用,後果自負 MySQL8.0 篇章 官網http://www.mysql.com/downloads/ 下載即可,無需激活 這裡只講配置: 1、下載後找到mysql的bin目錄,(mac系統中會自動生成別名,) mysq ...
  • 《採桑子·重陽》 人生易老天難老,歲歲重陽。 今又重陽,戰地黃花分外香。 一年一度秋風勁,不似春光, 勝似春光,寥廓江天萬里霜 視圖:是存儲在資料庫中的查詢的SQL 語句,它主要出於兩種原因:安全原因, 視圖可以隱藏一些數據,如:社會保險基金錶,可以用視圖只顯示姓名,地址,而不顯示社會保險號和工資數 ...
  • 第一題 某班學生和考試成績信息如下表Student所示: Student表 ID SName Mark 1 Jack 90 2 Marry 96 3 Rose 88 4 Bob 86 5 John 83 6 Belty 85 7 Robert 其中ID為學生的編號,SName為姓名,Mark為成績, ...
  • 二台sql伺服器配置ISCSI虛擬磁碟 在上篇我們利用ISCSI Target軟體在DC-ISCSCI上創建了三個ISCSI虛擬磁碟,在下麵我們將為大家介紹SQL-CL01(hsr1 50)和SQL-CL02(hsr2 51)如何訪問這些ISCSI虛擬磁碟. SQL-CL01和SQL-CL02可以使 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...