一文教會(huì)你在sqlserver中創(chuàng)建表
前言
SQL Server創(chuàng)建表是最常見(jiàn)也是最常用的操作之一,下面就為您介紹SQL Server創(chuàng)建表的語(yǔ)句寫(xiě)法,供您參考,希望可以讓您對(duì)SQL Server創(chuàng)建表方面有更深的認(rèn)識(shí)。
方法如下:
1:在sql語(yǔ)句中,臨時(shí)表有兩類,分別是局部(local)和全局(global)臨時(shí)表,局部臨時(shí)表只在其會(huì)話(事務(wù))中可見(jiàn),全局臨時(shí)表可以被會(huì)話(事務(wù))中的任何程序或者模塊訪問(wèn)
2:創(chuàng)建局部臨時(shí)表
use db_sqlserver go create table #db_local_table ( id int, name varchar(50), age int, area int )
創(chuàng)建的臨時(shí)表不能與其他會(huì)話共享,當(dāng)會(huì)話結(jié)束時(shí),行和表的定義都將被刪除
3:創(chuàng)建全局臨時(shí)表
use db_sqlserver go create table ##db_local_table ( id int, name varchar(50), age int, area int )
全局臨時(shí)表對(duì)所有用戶都是可見(jiàn)的,在每個(gè)訪問(wèn)該表的用戶都斷開(kāi)服務(wù)器連接時(shí),全局臨時(shí)表才會(huì)被刪除
4:創(chuàng)建主鍵、外鍵關(guān)聯(lián)的數(shù)據(jù)庫(kù)表
use db_sqlserver; go create table db_table5 ( 職工編號(hào) int primary key, 職工號(hào) varchar(50) unique, 倉(cāng)庫(kù)號(hào) varchar(50), 工資 int ) go create table db_table6 ( 訂單編號(hào) int primary key, 訂單號(hào) varchar(50) unique, 職工號(hào) varchar(50) references db_table5(職工號(hào)), 訂購(gòu)日期 datetime, 銷售金額 int )
5:創(chuàng)建具有check約束字段的數(shù)據(jù)庫(kù)表
use db_sqlserver; go create table db_table7 ( 倉(cāng)庫(kù)編號(hào) int primary key, 職工號(hào) varchar(50) unique, 倉(cāng)庫(kù)號(hào) varchar(50), 工資 int, 面積 int check(面積>=600 and 面積<=1800) )
6:創(chuàng)建含有計(jì)算字段的數(shù)據(jù)庫(kù)表
use db_sqlserver; go create table db_table8 ( 職工編號(hào) int primary key, 職工號(hào) varchar(50) unique, 倉(cāng)庫(kù)號(hào) varchar(50), 基本工資 int check(基本工資>=800 and 基本工資<=2100), 加班工資 int, 獎(jiǎng)金 int, 扣率 int, 應(yīng)發(fā)工資 as (基本工資 + 加班工資 + 獎(jiǎng)金 - 扣率) )
7:創(chuàng)建含有自動(dòng)編號(hào)字段的數(shù)據(jù)庫(kù)表
use db_sqlserver; go create table db_table9 ( 倉(cāng)庫(kù)編號(hào) int identity(1,1) primary key, 倉(cāng)庫(kù)號(hào) varchar(50) unique, 城市 varchar(50) default('青島'), 面積 int check(面積>=300 and 面積<=1800) )
向表中添加記錄:
insert into [db_sqlserver].[dbo].[db_table9](倉(cāng)庫(kù)號(hào), 面積) values('400', 1600);
倉(cāng)庫(kù)編號(hào)會(huì)自動(dòng)增加
8:創(chuàng)建含有排序字段的數(shù)據(jù)表
create table db_table10 ( 倉(cāng)庫(kù)編號(hào) int identity(1, 1) primary key, 倉(cāng)庫(kù)號(hào) varchar(50) collate french_CI_AI not null, 城市 varchar(50) default '青島', 面積 int check(面積>=300 and 面積<=1800) )
倉(cāng)庫(kù)號(hào)是一個(gè)排序字段,其中CI(case insensitive)表示不區(qū)分大小寫(xiě),AI(accent insensitive)表示不區(qū)分重音,即創(chuàng)建的是一個(gè)不區(qū)分大小寫(xiě)
和不區(qū)分重音的排序。如果要區(qū)分大小和和區(qū)分排序,修改代碼為:French_CS_AS
9:動(dòng)態(tài)判斷數(shù)據(jù)庫(kù)表是否存在
use db_sqlserver; go if(Exists(select * from sys.sysobjects where id=OBJECT_ID('db_table9'))) print '數(shù)據(jù)庫(kù)表名已經(jīng)存在' else print '該數(shù)據(jù)庫(kù)表名不存在,可以利用該名創(chuàng)建表'
10:查看表的各種信息,可以查看指定數(shù)據(jù)庫(kù)表的屬性、表中字段屬性、各種約束等信息
use db_sqlserver; go execute sp_help db_table9;
11:用select語(yǔ)句查看數(shù)據(jù)庫(kù)表的屬性信息
use db_sqlserver; go select * from sysobjects where type='U'
12:重命名數(shù)據(jù)庫(kù)表
use db_sqlserver; go execute sp_rename "db_table9", "db_renametable"
13:增加數(shù)據(jù)庫(kù)表的新字段
use db_sqlserver; go alter table db_table1 add 電子郵件 varchar(50) alter table db_table1 add 聯(lián)系方式 varchar(50) default '0532-88886396' select name 字段名, xusertype 類型編號(hào), length 長(zhǎng)度 from syscolumns where id = object_id('db_table1')
14:修改數(shù)據(jù)庫(kù)表的字段
use db_sqlserver; go alter table db_table1 alter column 電子郵件 varchar(200) select name 字段名, xusertype 類型編號(hào), length 長(zhǎng)度 from syscolumns where id = object_id('db_table1')
15:刪除數(shù)據(jù)庫(kù)表字段
use db_sqlserver; go alter table db_table1 drop column 電子郵件 select name 字段名, xusertype 類型編號(hào), length 長(zhǎng)度 from syscolumns where id = object_id('db_table1')
16:刪除數(shù)據(jù)庫(kù)表
use db_sqlserver; go drop table db_table1 drop table db_table1, db_table2
如果刪除有依賴關(guān)聯(lián)的數(shù)據(jù)庫(kù)表,即主鍵、外鍵關(guān)鍵表、則要?jiǎng)h除兩個(gè)表之間的關(guān)聯(lián)約束,然后才能刪除表。注意,也可以先刪除引用該表的數(shù)據(jù)庫(kù)表,然后
即可刪除該表,
總結(jié)
到此這篇關(guān)于在sqlserver中創(chuàng)建表的文章就介紹到這了,更多相關(guān)sqlserver創(chuàng)建表內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
sql?server設(shè)置數(shù)據(jù)庫(kù)某個(gè)字段值不能重復(fù)兩種方法
sqlserver的表中有一個(gè)列不能有相同的值,如何保證每次插入該列的值都是不同的,這篇文章主要給大家介紹了關(guān)于sql?server設(shè)置數(shù)據(jù)庫(kù)某個(gè)字段值不能重復(fù)的兩種方法,需要的朋友可以參考下2023-11-11利用sys.sysprocesses檢查SqlServer的阻塞和死鎖
Sys.SysProcesses 系統(tǒng)表是一個(gè)很重要的系統(tǒng)視圖,主要用來(lái)定位與解決Sql Server的阻塞和死鎖2011-10-10SQL?Server表空間碎片化回收的實(shí)現(xiàn)
本文主要介紹了SQL?Server表空間碎片化回收的實(shí)現(xiàn),文中根據(jù)實(shí)例編碼詳細(xì)介紹的十分詳盡,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-03-03SqlServer如何通過(guò)SQL語(yǔ)句獲取處理器(CPU)、內(nèi)存(Memory)、磁盤(Disk)以及操作系統(tǒng)相關(guān)信息
這篇文章主要介紹了SqlServer如何通過(guò)SQL語(yǔ)句獲取處理器(CPU)、內(nèi)存(Memory)、磁盤(Disk)以及操作系統(tǒng)相關(guān)信息的相關(guān)資料,需要的朋友可以參考下2015-11-11如何監(jiān)測(cè)和優(yōu)化OLAP數(shù)據(jù)庫(kù)
微軟SQL Server分析服務(wù)(SSAS)提供了一個(gè)用來(lái)創(chuàng)建和管理數(shù)據(jù)挖掘應(yīng)用和在線分析處理系統(tǒng)的強(qiáng)大引擎,你應(yīng)該仔細(xì)的監(jiān)測(cè)和優(yōu)化OLAP數(shù)據(jù)庫(kù)和潛在的關(guān)系數(shù)據(jù)源。2015-09-09SQL Server查找表名或列名中包含空格的表和列實(shí)例代碼
這篇文章主要給大家介紹了關(guān)于SQL Server如何查找表名或列名中包含空格的表和列的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起看看吧2018-09-09