一.表的创建:

CREATE TABLE [database_name.[schema_name].|schema_name.]table_name

(column_name1 data_type                 --列名

[ DEFAULT constant_expression]    --约束类型

[ IDENTITY ( SEED, INCREMENT )]  --列标识

[ NULL | NOT NULL ][ ,…n]         --是否允许为空

)

[ON { filegroup | DEFAULT } ]      --所在文件组

例.为sales数据库在文件组USER1上创建Category种类表

use sales

CREATE TABLE Category

(CategoryID int NOT NULL,

CategoryName nvarchar(15),

Description nvarchar(200),

NodeID char(8) IDENTITY(1,1)    --标识列标识从1开始递增,每次增幅为1

)

ON USER1

二.表结构的修改--增加、删除、修改列:

ALTER TABLE table_name

{ ADD column_name  date_type [DEFAULT  contant_expression]

[IDENTITY(SEED,INCREMENT)] [NULL | NOT NULL] [ ,…n]

| DROP  COLUMN  column_name

| ALTER  COLUMN  column_name  new_datetype  [NULL | NOT NULL ]

}

例.在数据库test的表Custom中增加Address列

ALTER TABLE Custom

ADD Address char(20)

删除xx列

ALTER TABLE Custom

DROP COLUMN xx

修改列:将Custom表中的Address字段的长度改为30,且不能为空

ALTER TABLE Custom

ALTER COLUMN Address char(30) not null

三.修改表中的内容--插入、删除:

1.在表中插入数据:

INSERT [ INTO ] table_name [ ( column_name [,…n] ) ]
VALUES ( expression | NULL | DEFAULT [,…n] )--expression为要插入的值,字符型与日期类型要加   ' '  号

例.在表Seller中插入下面数据

INSERT INTO Seller(SaleID,SaleName,Sex,Birthday,HireDate,Address,Telephone,Notes)

VALUES('01','张三',DEFAULT,'1974-07-25',NULL,NULL,NULL,DEFAULT)

--其中空值(null)可以不写出来,对应的列名也不必列出,对有默认值的可以使用DEFAULT使用默认值

--具有IDENTITY属性的列,其值由系统给出,用户不必向表中插入数据。

2.修改表中数据:

UPDATE table_name

SET column_name=expression [,…n]

[ WHERE search_conditions ]

3.删除表中数据:

DELETE [ FROM ] table_name
[ WHERE search_conditions]

四.创建表的约束:

总的语法格式:

CREATE TABLE table_name

( column_name data_type  [ [ CONSTRAINT constraint_name ] constraint_type ]

[,…n]  )

在已经创建的表中添加约束:

ALTER TABLE table_name

[ WITH CHECK | WITH NOCHECK ]

ADD [ CONSTRAINT constraint_name ] constraint_type

--WITH CHECK | WITH NOCHECK代表新加入的约束对表中现有的数据是否进行检查。

删除约束:

ALTER TABLE table_name

DROP CONSTRAINT constraint_name

1.创建主键约束:主键用于唯一地标识表中每一条记录。可以定义表中的一列或多列为主键。主键列的值不能重复,也不能为空值。

[ CONSTRAINT constraint_name ] PRIMARY KEY [ CLUSTERED | NONCLUSTERED ]

( col_name [,…n])

2.创建唯一约束:指定列上不可以有重复值

[ CONSTRAINT constraint_name ] UNIQUE [ CLUSTERED | NONCLUSTERED ]

( col_name [,…n])

3.创建CHECK约束:用来指定某列的可取值的范围。

[ CONSTRAINT constraint_name ] CHECK (exp)   --exp是表达式(表示条件、范围)

--作用:当向该表执行插入或更新操作时,SQL Server会检查插入的新列值是否满足CHECK约束的条件,若不满足,系统会报错,并拒绝执行插入或更新操作。

--注意:不能在具有IDENTITY属性的列上设置CHECK约束。

4. 创建DEFAULT约束:给表中指定列赋予默认值,当向该表插入数据时,如果用户没有明确给出该列的值,SQL Server会自动为该列输入默认值。每列只能有一个DEFAULT约束。

[ CONSTRAINT constraint_name ] DEFAULT (expression | NULL) FOR column_name

5.外键约束(Foreign key): 用于与其他表(主键表)中的列(称为主键列)建立连接。

[ CONSTRAINT constraint_name ]

FOREIGN KEY (col_name1[,…n])

REFERENCES table_name(column_name1[,…n])

其中:

col_name1[,…n]:是要实现外键约束的列。

table_name:是主键表(参照表)表名。

column_name1[,…n]:是主键列(参照列)列名。

例.

例3.31  若sales数据库中包含Seller表和Customer表。

Seller(SaleID、SaleName)

Customer(CustomerID、Company)

新建表Orders(OrderID、CustomerID、SaleID,OrderDate)

其中CustomerID、SaleID为外键。

CREATE TABLE Orders

(Orderid int PRIMARY KEY,

CustomerID char(3) REFERENCES Customer(CustomerID),

SaleID char(3) CONSTRAINT fk_sid REFERENCES Seller(SaleID),

OrderDate datetime DEFAULT getdate())

例.  修改OrderDetail表,在OrderID列上创建外键约束。

ALTER TABLE OrderDetail

ADD CONSTRAINT fk_orderid

FOREIGN KEY (OrderID) REFERENCES Orders(OrderID)

ALTER TABLE OrderDetail

WITH NOCHECK

ADD CONSTRAINT fk_orderid

FOREIGN KEY (OrderID) REFERENCES Orders(OrderID)

五.查看约束名:

sp_help student

或者:

sp_helpconstraint student

六.删除约束:

alter table_name

drop constraint  约束名

SQL常用语句之数据库中表的创建、删除以及属性的修改-篇幅3的更多相关文章

  1. SQL常用语句之数据库的创建、删除以及属性的修改-篇幅1

    本篇文章主要总结了SQL Server 语句的使用和一些基础知识,因为目前我也正在学习,所以总结一下. 要使用数据库语句,首先就要知道数据库对象的结构: 通常情况下,如果不会引起混淆,可以直接使用对象 ...

  2. SQL常用语句之数据库数据类型-篇幅2

    系统数据类型: 1.二进制数据类型      2.整数数据类型 3.浮点数据类型         4.精确小数数据类型 5.货币数据类型         6.日期/时间数据类型 7.字符数据类型    ...

  3. Oracle和SQL server查询数据库中表的创建和最后修改时间

    有时候我们需要查看下数据数据库中表的创建时间和最后修改时间,可以通过以下语句实现: Oracle数据库 -- 查看当前用户下的表 SELECT * FROM USER_TABLES -- 查看数据库中 ...

  4. 【数据库】 SQL 常用语句

    [数据库] SQL 常用语句 1.批量导入 INSERT INTO Table2(field1,field2,...) SELECT value1,value2,... FROMTable1 要求目标 ...

  5. 【数据库】 SQL 常用语句之系统语法

    [数据库] SQL 常用语句之系统语法 1. 获取取数据库服务器上所有数据库的名字 SELECT name FROM master.dbo.sysdatabases 2. 获取取数据库服务器上所有非系 ...

  6. SQL常用语句(二)

    --语 句 功 能--数据操作SELECT --从数据库表中检索数据行和列INSERT --向数据库表添加新数据行DELETE --从数据库表中删除数据行UPDATE --更新数据库表中的数据 --数 ...

  7. mysql sql常用语句大全

    SQL执行一次INSERT INTO查询,插入多行记录 insert into test.person(number,name,birthday) values(5,'cxx5',now()),(6, ...

  8. mysql sql常用语句

    1.说明:创建数据库 CREATE DATABASE database-name 2.说明:删除数据库 drop database dbname 3.说明:备份sql server --- 创建 备份 ...

  9. ORACLE数据库 常用命令和Sql常用语句

    ORACLE 账号相关 如何获取表及权限 1.COPY表空间backup scottexp登录管理员账号system2.创建用户 create user han identified(认证) by m ...

随机推荐

  1. C# 中常见的控件以及功能

    1.StatusBar控件——显示各种状态信息. StatusBar控件可以有状态栏面板(用于显示图标以指示状态)或一系列动画图标(用于指示某个进程正在工作,例如,表示正在保存文档的 Microsof ...

  2. SQLyog安装

    安装 使用 首先看到下面的界面

  3. 1、获取ip地址

    1.获取ip地址 System.Net.NetworkInformation.NetworkInterface.GetAllNetworkInterfaces() .Select(p => p. ...

  4. IPC之套接字

    IPC(Inter-Process Communication,进程间通信)实现方式 1)管道: - 管道是一种半双工的通信方式,数据只能单向流动,而且只能在具有亲缘关系的进程之间使用(进程的亲缘关系 ...

  5. 基于celery的任务管理

    1.celery基本原理 Celery是一个由python编写的简单.灵活.可靠的用来处理大量信息的分布式系统,同时提供了操作和维护分布式系统所需要的工具,说白了就是一个用来管理分布式队列的工具. C ...

  6. 新特性2-lambda表达式

    最近几天学习了一下lambda表达式,看了不少博客,感觉有一篇博客总结的一句话总结的很好:lambda表达式是一段可以传递的代码,它的核心思想是将面向对象中的传递数据变成传递行为.其实以前也有传递行为 ...

  7. springboot+UEditor图片上传

    springboot+UEDitor百度编辑器整合图片上记录于此 1.下载ueditor插件包,解压到static/ueditor目录下 2.在你所需实现编辑器的页面引用三个JS文件 1)  uedi ...

  8. 2018-09-25-weekly

    Algorithm 两数相加 What 给定两个非空链表来表示两个非负整数.位数按照逆序方式存储,它们的每个节点只存储单个数字.将两数相加返回一个新的链表. How 两个链表长度相同的部分,对位相加, ...

  9. 2018-09-20-weekly

    Algorithm 最长有效括号 What 给定一个只包含 '(' 和 ')' 的字符串,找出最长的包含有效括号的子串的长度. How 这里可以用栈来求解,需要定义个start变量来记录合法括号串的起 ...

  10. POJ 3889 Fractal Streets(逼近模拟)

    $ POJ~3889~Fractal~Streets $(模拟) $ solution: $ 这是一道淳朴的模拟题,最近发现这种题目总是可以用逼近法,就再来练练手吧. 首先对于每个编号我们可以用逼近法 ...