網站首頁 編程語言 正文
前言
SQL Server創建表是最常見也是最常用的操作之一,下面就為您介紹SQL Server創建表的語句寫法,供您參考,希望可以讓您對SQL Server創建表方面有更深的認識。
方法如下:
1:在sql語句中,臨時表有兩類,分別是局部(local)和全局(global)臨時表,局部臨時表只在其會話(事務)中可見,全局臨時表可以被會話(事務)中的任何程序或者模塊訪問
2:創建局部臨時表
use db_sqlserver
go
create table #db_local_table
(
id int,
name varchar(50),
age int,
area int
)
創建的臨時表不能與其他會話共享,當會話結束時,行和表的定義都將被刪除
3:創建全局臨時表
use db_sqlserver
go
create table ##db_local_table
(
id int,
name varchar(50),
age int,
area int
)
全局臨時表對所有用戶都是可見的,在每個訪問該表的用戶都斷開服務器連接時,全局臨時表才會被刪除
4:創建主鍵、外鍵關聯的數據庫表
use db_sqlserver;
go
create table db_table5
(
職工編號 int primary key,
職工號 varchar(50) unique,
倉庫號 varchar(50),
工資 int
)
go
create table db_table6
(
訂單編號 int primary key,
訂單號 varchar(50) unique,
職工號 varchar(50) references db_table5(職工號),
訂購日期 datetime,
銷售金額 int
)
5:創建具有check約束字段的數據庫表
use db_sqlserver;
go
create table db_table7
(
倉庫編號 int primary key,
職工號 varchar(50) unique,
倉庫號 varchar(50),
工資 int,
面積 int check(面積>=600 and 面積<=1800)
)
6:創建含有計算字段的數據庫表
use db_sqlserver;
go
create table db_table8
(
職工編號 int primary key,
職工號 varchar(50) unique,
倉庫號 varchar(50),
基本工資 int check(基本工資>=800 and 基本工資<=2100),
加班工資 int,
獎金 int,
扣率 int,
應發工資 as (基本工資 + 加班工資 + 獎金 - 扣率)
)
7:創建含有自動編號字段的數據庫表
use db_sqlserver;
go
create table db_table9
(
倉庫編號 int identity(1,1) primary key,
倉庫號 varchar(50) unique,
城市 varchar(50) default('青島'),
面積 int check(面積>=300 and 面積<=1800)
)
向表中添加記錄:
insert into [db_sqlserver].[dbo].[db_table9](倉庫號, 面積) values('400', 1600);
倉庫編號會自動增加
8:創建含有排序字段的數據表
create table db_table10
(
倉庫編號 int identity(1, 1) primary key,
倉庫號 varchar(50) collate french_CI_AI not null,
城市 varchar(50) default '青島',
面積 int check(面積>=300 and 面積<=1800)
)
倉庫號是一個排序字段,其中CI(case insensitive)表示不區分大小寫,AI(accent insensitive)表示不區分重音,即創建的是一個不區分大小寫
和不區分重音的排序。如果要區分大小和和區分排序,修改代碼為:French_CS_AS
9:動態判斷數據庫表是否存在
use db_sqlserver;
go
if(Exists(select * from sys.sysobjects where id=OBJECT_ID('db_table9')))
print '數據庫表名已經存在'
else
print '該數據庫表名不存在,可以利用該名創建表'
10:查看表的各種信息,可以查看指定數據庫表的屬性、表中字段屬性、各種約束等信息
use db_sqlserver;
go
execute sp_help db_table9;
11:用select語句查看數據庫表的屬性信息
use db_sqlserver;
go
select * from sysobjects where type='U'
12:重命名數據庫表
use db_sqlserver;
go
execute sp_rename "db_table9", "db_renametable"
13:增加數據庫表的新字段?
use db_sqlserver;
go
alter table db_table1 add 電子郵件 varchar(50)
alter table db_table1 add 聯系方式 varchar(50) default '0532-88886396'
select name 字段名, xusertype 類型編號, length 長度 from syscolumns where id = object_id('db_table1')
14:修改數據庫表的字段
use db_sqlserver;
go
alter table db_table1 alter column 電子郵件 varchar(200)
select name 字段名, xusertype 類型編號, length 長度 from syscolumns where id = object_id('db_table1')
15:刪除數據庫表字段
use db_sqlserver;
go
alter table db_table1 drop column 電子郵件
select name 字段名, xusertype 類型編號, length 長度 from syscolumns where id = object_id('db_table1')
16:刪除數據庫表
use db_sqlserver;
go
drop table db_table1
drop table db_table1, db_table2
如果刪除有依賴關聯的數據庫表,即主鍵、外鍵關鍵表、則要刪除兩個表之間的關聯約束,然后才能刪除表。注意,也可以先刪除引用該表的數據庫表,然后
即可刪除該表,
總結
原文鏈接:https://bogeit.blog.csdn.net/article/details/7333893
相關推薦
- 2022-03-19 C#(.Net)將非托管dll嵌入exe中的實現_C#教程
- 2022-10-05 Python中matplotlib庫安裝失敗的經驗總結(附pycharm配置anaconda)_py
- 2022-07-21 nginx?配置指令之location使用詳解_nginx
- 2022-05-08 C++中如何修改const變量你知道嗎_C 語言
- 2022-04-28 在vmware虛擬機安裝dpdk的詳細過程_VMware
- 2023-05-31 E:?無法定位軟件包?python3-pip問題及解決_python
- 2023-03-18 Kotlin?Fragment使用方法詳解_Android
- 2022-03-17 golang?數組隨機排序的實現_Golang
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支