需要新建一個用戶,用本地帳戶登陸進去,
然後安全性_>登錄名_>右鍵新建用戶登錄名_>常規里輸入用戶名kyle_>選擇sqlServer身份驗證在輸入密碼,下面的強制實施密碼策略和強制密碼過期保持默認,由於我們已經設置了我們想要的密碼去掉「用戶在下次登陸時必須更改密碼」的勾,選擇默認資料庫。伺服器角色我們可以根據需要來設置,我這里不勾選,因為我只需要這個帳戶只能訪問某些資料庫的許可權,用戶角色裡面「映射到此登錄名的用戶」選擇選擇你要訪問的資料庫,然後在「資料庫角色成員身份」這里選擇上db_owner和public,這兩個角色就表示你已經擁有這個資料庫的所有許可權。還需要在狀態裡面「是否允許連接到資料庫引擎」選擇授予和在「登陸」裡面選擇啟用
② sql資料庫中包含哪幾種文件
sql資料庫中包含主數據文件、事務日誌文件、輔助數據文件三種文件。
1、主數據文件
該文件包含資料庫的啟動信息,並用於存儲數據。每個資料庫都有一個主要數據文件。
2、事務日誌文件
這些文件包含用於恢復資料庫的日誌信息。每個資料庫都必須至少有一個日誌文件。
3、輔助數據文件
這些文件含有不能置於主要數據文件中的所有數據。如果主文件可以包含資料庫中的所有數據,那麼資料庫就不需要次要數據文件。
(2)sql資料庫只能有一個什麼擴展閱讀
sql資料庫特點
1、SQL資料庫的數據體系結構基本上是三級結構,但使用術語與傳統關系模型術語不同。在SQL中,關系模式(模式)稱為「基本表」(basetable);存儲模式(內模式)稱為「存儲文件」(storedfile);子模式(外模式)稱為「視圖」(view);元組稱為「行」(row);屬性稱為「列」(column)。
2、sql資料庫是非過程化語言、統一的語言、是所有關系型資料庫的公共語言。
3、SQL用戶可以是應用程序,也可以是終端用戶。SQL語句可嵌入在宿主語言的程序中使用,宿主語言有FORTRAN,COBOL,PASCAL,PL/I,C和Ada語言等。SQL用戶也能作為獨立的用戶介面,供交互環境下的終端用戶使用。
③ sql 判斷題 一個資料庫可以有多個邏輯模式
不管是邏輯模式(外模式)還是物理模式(內模式),一個資料庫都分別只能有一個。
④ 用SQL語句寫,每一個庫里邊只能有一個IDENTITY標識嗎
不是 每個表維護自己的IDENTITY標識(最多隻能有一個),但是不同表的IDENTITY是不會相互影響的
⑤ SQL中一個表可以有幾個聚集索引或非聚集索引
一個表只能有一個聚集索引,可以有多個非聚集索引
下面是聚集索引和非聚集索引的詳細介紹:
聚集索引基於數據行的鍵值在表內排序和存儲這些數據行。每個表只能有一個聚集索引,因為數據行本身只能按一個順序存儲。有關聚集索引體系結構的詳細信息,請參閱聚集索引結構。
每個表幾乎都對列定義聚集索引來實現下列功能:
可用於經常使用的查詢。
提供高度唯一性。
注意:
創建 PRIMARY KEY 約束時,將在列上自動創建唯一索引。默認情況下,此索引是聚集索引,但是在創建約束時,可以指定創建非聚集索引。
可用於范圍查詢。
如果未使用 UNIQUE 屬性創建聚集索引,資料庫引擎將向表自動添加一個 4 位元組的 uniqueifier
列。必要時,資料庫引擎將向行自動添加一個 uniqueifier 值以使每個鍵唯一。此列和列值供內部使用,用戶不能查看或訪問。
查詢注意事項
在創建聚集索引之前,應先了解數據是如何被訪問的。考慮對具有以下特點的查詢使用聚集索引:
使用運算符(如 BETWEEN、>、>=、< 和
<=)返回一系列值。
使用聚集索引找到包含第一個值的行後,便可以確保包含後續索引值的行物理相鄰。例如,如果某個查詢在一系列銷售訂單號間檢索記錄,SalesOrderNumber
列的聚集索引可快速定位包含起始銷售訂單號的行,然後檢索表中所有連續的行,直到檢索到最後的銷售訂單號。
返回大型結果集。
使用 JOIN 子句;一般情況下,使用該子句的是外鍵列。
使用 ORDER BY 或 GROUP BY 子句。
在 ORDER BY 或 GROUP BY
子句中指定的列的索引,可以使資料庫引擎不必對數據進行排序,因為這些行已經排序。這樣可以提高查詢性能。
列注意事項
一般情況下,定義聚集索引鍵時使用的列越少越好。考慮具有下列一個或多個屬性的列:
唯一或包含許多不重復的值
例如,雇員 ID 唯一地標識雇員。EmployeeID 列的聚集索引或 PRIMARY KEY
約束將改善基於雇員 ID 號搜索雇員信息的查詢的性能。另外,可對
LastName、FirstName、MiddleName
列創建聚集索引,因為經常以這種方式分組和查詢雇員記錄,而且這些列的組合還可提供高區分度。
按順序被訪問
例如,產品 ID 唯一地標識 AdventureWorks2008R2 資料庫的
Proction.Proct 表中的產品。在其中指定順序搜索的查詢(如 WHERE ProctID BETWEEN 980
and 999)將從 ProctID 的聚集索引受益。這是因為行將按該鍵列的排序順序存儲。
由於保證了列在表中是唯一的,所以定義為 IDENTITY。
經常用於對表中檢索到的數據進行排序。
按該列對表進行聚集(即物理排序)是一個好方法,它可以在每次查詢該列時節省排序操作的成本。
聚集索引不適用於具有下列屬性的列:
頻繁更改的列
這將導致整行移動,因為資料庫引擎必須按物理順序保留行中的數據值。這一點要特別注意,因為在大容量事務處理系統中數據通常是可變的。
寬鍵
寬鍵是若干列或若干大型列的組合。所有非聚集索引將聚集索引中的鍵值用作查找鍵。為同一表定義的任何非聚集索引都將增大許多,這是因為非聚集索引項包含聚集鍵,同時也包含為此非聚集索引定義的鍵列。
索引選項
創建聚集索引時,可指定若干索引選項。因為聚集索引通常都很大,所以應特別注意下列選項:
SORT_IN_TEMPDB
DROP_EXISTING
FILLFACTOR
ONLINE
非聚集索引包含索引鍵值和指向表數據存儲位置的行定位器。有關非聚集索引體系結構的詳細信息,請參閱非聚集索引結構。
可以對表或索引視圖創建多個非聚集索引。通常,設計非聚集索引是為改善經常使用的、沒有建立聚集索引的查詢的性能。
與使用書中索引的方式相似,查詢優化器在搜索數據值時,先搜索非聚集索引以找到數據值在表中的位置,然後直接從該位置檢索數據。這使非聚集索引成為完全匹配查詢的最佳選擇,因為索引包含說明查詢所搜索的數據值在表中的精確位置的項。例如,為了從
Person.Person 表中查詢具有特定姓氏的人員,查詢優化器可能使用非聚集索引
IX_Person_LastName_FirstName_MiddleName;它以 LastName 作為自己的一個鍵列。查詢優化器能快速找出索引中與指定
LastName
匹配的所有項。每個索引項都指向表或聚集索引中准確的頁和行,其中可以找到相應的數據。在查詢優化器在索引中找到所有項之後,它可以直接轉到准確的頁和行進行數據檢索。
資料庫注意事項
設計非聚集索引時需要注意資料庫的特徵。
更新要求較低但包含大量數據的資料庫或表可以從許多非聚集索引中獲益從而改善查詢性能。與全表非聚集索引相比,考慮為定義完善的數據子集創建篩選索引可以提高查詢性能、降低索引存儲開銷並減少索引維護開銷。
決策支持系統應用程序和主要包含只讀數據的資料庫可以從許多非聚集索引中獲益。查詢優化器具有更多可供選擇的索引用來確定最快的訪問方法,並且資料庫的低更新特徵意味著索引維護不會降低性能。
聯機事務處理應用程序和包含大量更新表的資料庫應避免使用過多的索引。此外,索引應該是窄的,即列越少越好。
一個表如果建有大量索引會影響
INSERT、UPDATE、DELETE 和 MERGE
語句的性能,因為當表中的數據更改時,所有索引都須進行適當的調整。
查詢注意事項
在創建非聚集索引之前,應先了解訪問數據的方式。考慮對具有以下屬性的查詢使用非聚集索引:
使用 JOIN 或 GROUP BY
子句。
應為聯接和分組操作中所涉及的列創建多個非聚集索引,為任何外鍵列創建一個聚集索引。
不返回大型結果集的查詢。
創建篩選索引以覆蓋從大型表中返回定義完善的行子集的查詢。
包含經常包含在查詢的搜索條件(例如返回完全匹配的 WHERE 子句)中的列。
列注意事項
考慮具有以下一個或多個屬性的列:
覆蓋查詢。
當索引包含查詢中的所有列時,性能可以提升。查詢優化器可以找到索引內的所有列值;不會訪問表或聚集索引數據,這樣就減少了磁碟
I/O 操作。使用具有包含列的索引來添加覆蓋列,而不是創建寬索引鍵。有關詳細信息,請參閱
具有包含列的索引
。
如果表有聚集索引,則該聚集索引中定義的列將自動追加到表上每個非聚集索引的末端。這可以生成覆蓋查詢,而不用在非聚集索引定義中指定聚集索引列。例如,如果一個表在
C 列上有聚集索引,則 B 和 A 列的非聚集索引將具有其自己的鍵值列 B、A 和 C。
大量非重復值,如姓氏和名字的組合(前提是聚集索引被用於其他列)。
如果只有很少的非重復值,例如僅有 1 和
0,則大多數查詢將不使用索引,因為此時表掃描通常更有效。對於這種類型的數據,應考慮對僅出現在少數行中的非重復值創建篩選索引。例如,如果大部分值都是
0,則查詢優化器可以對包含 1 的數據行使用篩選查詢。
索引選項
在創建非聚集索引時,可以指定若干索引選項。要尤其注意以下選項:
FILLFACTOR
ONLINE
⑥ 一個資料庫至多有幾個主數據文件
一個資料庫只能有一個主數據文件,可以有0個或多個次數據文件。
⑦ SQL 資料庫中,一張表只能有一個聚集索引嗎
是的,因為聚集索引決定了表的存儲時的排序,一個表只能有一個物理存儲排序,所以只能有一個聚集索引
⑧ sql 一個欄位只能一個值嗎
答案是肯定的。
當然也可以存多個值,如欄位name,字元串類型,存放兩個值:張三和李四;但是這種違反資料庫範式的存儲多個值,資料庫是允許的;而你在想獲取張三的時候就需要額外處理,無法體現資料庫的查詢性能。
⑨ sql怎麼設置兩個主鍵
sql資料庫中只能有一個主鍵!你說的應該是主外鍵的關系吧!假如:你建了一個user表
裡面有一個[age],你在useradmin表裡也建一個[age]並設置成主鍵,然後user表和useradmin表建立好主外鍵約束就可以應用到了
⑩ sql資料庫中一共有哪些約束 各是什麼意思
not null(非空),unique(唯一),primary key(非空,唯一,只能有一個主鍵),foreign(外鍵),check(強制數據滿足要求)