一、创建表

1.1、使用SQL Server Management Studio创建表

①、打开刚刚建立的CollegeSystemDB数据库,找到表(数据库->CollegeSystemDB->表)。右键单击表,选择新建表。

②、在点击新建表出来的界面中按照下图输入

③、按Ctrl+S或者点击最上面菜单栏中的文件,选择保存。输入欲保存的表名称student,并点击确定。

④、再次点击新建表,按照下图输入,并且保存为course。

⑤、再次点击新建表,按照下图输入,并且保存为stucourse。

⑥、在 数据库->CollegeSystemDB->表 那里刷新一下,就会发现刚刚建立的三张表了。

(选择 数据库->CollegeSystemDB->表->dbo.student 右键单击选择设计,就可以查看刚刚建立的表的具体信息了。)

1.2、使用SQL语句创建表

①、选择 数据库->CollegeSystemDB,然后选择新建查询。注意左上角的那个框中要选中CollegeSystemDB,如果不是的话就手动选择一下。

②、在新建查询出来的界面中输入以下代码:

-- 设置使用的数据库
USE CollegeSystemDB
GO -- 判断数据库中是否存在student表,如果存在则删除student表
IF EXISTS (SELECT * FROM sys.sysobjects WHERE name = 'student')
DROP TABLE student;
-- 创建student数据表
CREATE TABLE [dbo].[student](
[id] [int] NOT NULL PRIMARY KEY IDENTITY(10000,1),
[sno] [varchar](32) NOT NULL,
[sname] [varbinary](50) NOT NULL,
[sage] [int] NULL,
[sgender] [int] NOT NULL,
[sclass] [int] NULL,
[sgrade] [int] NULL,
); -- 判断数据库中是否存在course表,如果存在则删除course表
IF EXISTS (SELECT * FROM sys.sysobjects WHERE name = 'course')
DROP TABLE course;
-- 创建course数据表
CREATE TABLE [dbo].[course](
[id] [int] NOT NULL PRIMARY KEY IDENTITY(10000,1),
[cno] [varchar](32) NOT NULL,
[cname] [varchar](50) NOT NULL,
[createtime] [datetime] NULL,
[updatetime] [datetime] NULL
); -- 判断数据库中是否存在学生选课表stucourse表,如果存在则删除stucourse表
IF EXISTS (SELECT * FROM sys.sysobjects WHERE name = 'stucourse')
DROP TABLE stucourse;
-- 创建stucourse数据表
CREATE TABLE [dbo].[stucourse](
[id] [int] NOT NULL PRIMARY KEY IDENTITY(10000,1),
--列名 字段类型 是否为空 标识外键列(外键列名)关联表的表名(关联的字段名)
[sid] int NULL FOREIGN KEY(sid) REFERENCES student(id),
[cid] int NULL FOREIGN KEY(cid) REFERENCES course(id)
);

③、点击执行

④、在 数据库->CollegeSystemDB->表 那里刷新一下,就会发现刚刚建立的三张表了。

(选择 数据库->CollegeSystemDB->表->dbo.student 右键单击选择设计,就可以查看刚刚建立的表的具体信息了。)

二、列数据类型

  在关系数据库中,每一个关系都表现为一张表。表是用来存储数据和操作数据的逻辑结构,关系数据库中的所有数据都表现为表的形式,由列和行组成,如图3-1所示。关系数据库由表、具体查询等对象组成,而查询等对象又是通过表来呈现的。

  2.1、表的数据类型

2.2、数据类型使用分析

1.char,varchar,nchar,nvarchar

char性能好;varchar节省空间;
选择方法:10个字节以上的用varchar,nvarchar类型的占用空间大,性能低,如果不准备存中文或中亚文字则尽量避免使用。
尤其向类似工号的字段更不要使用n类型,ESL首先它不会存入中文,其次它可能作为索引,此时对性能的影响就更大。

2.datetime和smalldatetime

  datetime:从1753年1月1日到9999年12月31日的日期和时间数据,精确到毫秒。
  smalldatetime:从1900年1月1日到2079年6月6日的日期和时间数据,精确到分钟。

3.bigint,int,smallint,tinyint和bit

  bigint:从-2^63(-9223372036854775808)到2^63-1(9223372036854775807)的整型数据。
  int:从-2^31(-2,147,483,648)到2^31-1(2,147,483,647)的整型数据。
  smallint:从-2^15(-32,768)到2^15-1(32,767)的整数数据。
  tinyint:从0到255的整数数据。
  bit:1或0的整数数据。
  首先int,空间占用合适,运算速度快;(2147,...,...2个多亿)
  如果非常在意空间的话,考虑tinyint,超大应用场合,考虑bigint

4.decimal和numeric

  这两种数据类型是等效的。都有两个参数:p(精度)和s(小数位数)。p指定小数点左边和右边可以存储的十进制数字的最大个数,p必须是从 1到38之间的值。s指定小数点右边可以存储的十进制数字的最大个数,s必须是从0到p之间的值,默认小数位数是0。

5.float和real

  float:从-1.79^308到1.79^308之间的浮点数字数据。
  real:从-3.40^38到3.40^38之间的浮点数字数据。在SQL Server中,real的同义词为float(24)。

6.money,smallmoney

  尽量考虑用decimal替代,原因:性能稍稍好一些;相对其它数据库兼容性好。
  money的好处是可以用到某些货币运算函数。
  float类型尽量少用,性能不好,精度不高,一般只用于科学计算。

7.text/image

  考虑到维护方便、效率以及程序开发的方便性,最好不用,即不将其存入数据库中;采用varchar指向其相应的存储路径

三、表的完整性

  表的完整性分为实体完整性、引用完整性、域完整性、自定义完整性

3.1、实体完整性

  要求表中的每一行都反映不同的实体。通过索引、唯一约束、主键约束或者标识列来实现

3.2、引用完整性

  用于定义主表之间的关系,保证从表中外键列不会出现主表中对应主键列没有的项

3.3、域完整性

  表示给定输入的有效性。通过限制数据类型、检查约束、输入格式、外键约束、非空约束等方法来实现

3.4、自定义完整性

  用户自定义完整性用来定义特定的规则

四、向表中添加数据

五、查看表

六、修改表

七、删除表

  语法格式:DELETE TABLE

MSSQL → 04:表的创建与维护的更多相关文章

  1. MySQL表的创建与维护

    一.导入测试数据 [root@server ~]# wget https://launchpadlibrarian.net/24493586/employees_db-full-1.0.6.tar.b ...

  2. mssql 返回表的创建语句

    if OBJECT_ID('sp_create_table_sql','P') is not null drop proc sp_create_table_sql go create proc sp_ ...

  3. oracle表空间创建及管理

    一.数据文件和数据库逻辑存储结构: 一个表空间包含一个或多个数据文件,一个表空间包含一个或多个段,一个段包含一个或多个区,一个区包含一个或多个连续的数据库块,一个数据库块包含一个或多个操作系统块.段是 ...

  4. SQL语句(一)SQL和数据库数据表的创建

    SQL的组成 (1) 数据定义语言DDL(Data Definition Language) 用于数据库和数据表的创建.修改和删除等操作 CREATE (create) 创建数据库.数据表 ALTER ...

  5. 【Oracle 】tablespace 表空间创建和管理

    1.表空间的概述 1. 表空间是数据库的逻辑组成部分. 2. 从物理上讲,数据库数据存放在数据文件中: 3. 从逻辑上讲,数据库是存放在表空间中,表空间由一个或者多个数据文件组成. 2.oracle的 ...

  6. oracle 表的创建与管理 约束

    在 Oracle 之中数据表就被称为数据库对象,而对象的操作语法一共有三种:· 创建对象:CREATE 对象类型 对象名称 [选项]:· 删除对象:DROP 对象类型 对象名称 [选项]:· 修改对象 ...

  7. Oracle 表空间的日常维护与管理

    目录 Oracle 表空间的日常维护与管理 1.创建数据表空间 2.创建临时表空间 3.创建 UNDO 表空间 4.表空间的扩展与修改大小 5.表空间重命名 6.表空间的删除 7.更改表空间的读写模式 ...

  8. SQL基本操作——表的创建

    通过代码方式创建数据库 create database MyDatabaseNew on primary ( --名字 name='MyDatabaseNew_data', --路径 filename ...

  9. SQL概要与表的创建

    SQL概要与表的创建 1.表的结构 ​ 关系数据库通过类似Excel 工作表那样的.由行和列组成的二维表来管理数据.用来管理数据的二维表在关系数据库中简称为表. ​ 根据SQL 语句的内容返回的数据同 ...

随机推荐

  1. java后台使用HttpURLConnection实现百度主动推送

    优点是快 不需要页面执行,,发布文章之后立即推送,所以,不管有没有人访问,都可以自动实时推送 尝试了一下httpclient,没找到相关资料,post方式无法塞url进去 最后改为 import ja ...

  2. WhaleCTF之web-Find me

    WhaleCTF之web-Find me 前往题目 Where is the flag?这是给我提示吗? 没思路,看看源码,说不定有惊喜 哇,在这里啊,得到flag~ flag:{This_is_s0 ...

  3. [转载] OpenCV2.4.3 CheatSheet学习(三)

    四.图像处理(呵呵,重头戏来了) 1. 滤波 filter2D() 用核函数对图像做卷积. sepFilter2D() 用分解的核函数对图像做卷积. 首先,图像的每一行与一维的核kernelX做卷积: ...

  4. JQuery学习:jquery对象和js对象区别和转换

    JQuery对象与JS对象区别与转换 1.JQuery对象在操作时,更加方便 2.JQuery对象和js对象方法不通用 3.两者相互转换 *  jq -- > js:jq对象[索引]  或者  ...

  5. Luogu P2292 [HNOI2004]L语言(Trie+dp)

    P2292 [HNOI2004]L语言 题面 题目描述 标点符号的出现晚于文字的出现,所以以前的语言都是没有标点的.现在你要处理的就是一段没有标点的文章. 一段文章 \(T\) 是由若干小写字母构成. ...

  6. golang 程序 在linux 出现 段错误

    刚做的 golang 程序 发布到linux 竟然出现 段错误 原因是 内核版本过低,请升级内核

  7. 获取MMSQL数据库表信息

    SELECT 表名 then d.name else '' end, 表说明 then isnull(f.value,'') else '' end, 字段序号=a.colorder, 字段名=a.n ...

  8. androidstudio实现增量更新步骤

    本文demo和参考例子参考-传送  门:http://blog.csdn.net/duguang77/article/details/17676797 一.增量更新优点:节省客户端和服务器端流量 增量 ...

  9. 基于RBAC权限管理的后台管理系统

    在摸爬滚打中渐渐理解了RBAC权限管理是个什么玩意. RBAC的基本概念: **RBAC认为权限授权实际上是Who.What.How的问题.在RBAC模型中,who.what.how构成了访问权限三元 ...

  10. day38 07-Spring框架Bean的时候方式

    Spring是自动帮我们创建对象的,有几种创建Bean的方式呢? 构造方法实例化:(默认无参数)其实就是反射new Instance(). 静态工厂实例化: 实例工厂实例化: 一般不会改变它实例化的方 ...