数据库表的管理

  表的基本概念

        表是包含数据库中所有数据的数据库对象。数据在表中的组织方式与在电子表格中相似,都是 按行和列的格式组织的。每行代表一条唯一的记录,每列代表记录中的一个字段。例如,在包含公 司员工信息的表中,每行代表一名员工,各列分别代表该员工的信息,如编号、姓名、身份证号、 职务,出生日期、基本工资等。

3aae6811506540fca2bb1b103102d0fa.png

 

SQL Server 中的表包括下列主要组件

>列:每列代表由表建模的对象的某个属性。例如,员工表有编号列、姓名列和职务列等。

>行:每行代表由表建模的对象的一个单独的实例。例如,公司每名员工在表中均占一行。

 

数据完整性

        数据完整性是指数据的精确性和可靠性,它是为防止数据库中存在不符合语义规定的数据和防止因错误信息的输入/输出造成无效操作或错误信息而提出的,它分为以下四类。

1.实体完整性

        实体完整性将行定义为特定表的唯一实体。实体完整性通过UNOUE(唯一)索引.UNIQUE约束 或PRIMARY KEY(主键)约束,强制表的标识列或主键的完整性。

2.域完整性

        域完整性指特定列的项的有效性。可以强制域完整性限制类型(通过使用数据类型)、限制格式 (通过使用CHECK约束和规则)或限制可能值的范围(通过使用FOREIGN KEY约束、CHECK约束、 DEFAULT 定义、NOT NULL定义和规则)。

3.引用完整性

        输入或删除行时,引用完整性保留表之间定义的关系。在 SQL Server中,引用完整性通过 FOREIGNKEY(外键)和CHECK(检查)约束,以外键与主键之间或外键与唯一键之间的关系为基础。 引用完整性确保键值在所有表中一致。这类一致性要求不引用不存在的值,如果一个键值发生更改, 则整个数据库中对该键值的所有引用都要进行一致的更改。

        强制引用完整性时,SQL Server将防止用户执行下列操作。

        >在主表中没有关联行的情况下在相关表中添加或更改行。

        >在主表中更改值(可导致相关表中出现孤立行)。

        >在有匹配的相关行的情况下删除主表中的行。

4.用户定义完整性

        用户定义完整性可以定义不属于其他任何完整性类别的特定业务规则。所有完整性类别都支持 用户定义完整性,这包括CREATE TABLE 中所有列级约束和表级约束、存储过程及触发器。

 

主键

        主键唯一标识表中的行数据,一个主键值对应一行数据。主键由一个或多个字段组成,其值具 有唯一性,而且不允许取空值(NULL),一个表只能有一个主键。

        如果主键由多个列组成,则其中一个列将允许重复值,但是主键中所有列的值的各种组合必须是唯一的。

        定义主键可以对在不允许空值的指定列中输入的值强制其唯一性。如果为数据库中的某个表定 义了主键,则可将该表与其他表相关联,从而减少对冗余数据的需求。

数据类型

数据类型是数据的一种属性,用于指定对象可保存的数据的类型,如整数数据、字符数据、货 币数据、日期和时间数据、字符串等。

        >SQL Server提供系统数据类型集,该类型集定义了可与SOL Server一起使用的所有数据类型。

        >SQL Server 中的数据类型可以归纳为下列类别:精准数字、近似数字、日期和时间、字符串、 Unicode 字符串、二进制字符串、其他数据类型。下面分别对一些常见的数据类型进行介绍。

精准数字可以分为九种数据类型

669be780b3e1438f8d7b9f3b52e6ae15.png

 

近似数字可以分为两种数据类型 

881cf42abc0c4af895a9be83cfae9a9b.png

 

日期和时间可以分为六种数据类型 

3cddba02897348d5b4c8a3f07ddf6542.png

字符串可以分为三种数据类型 

63aeba870da1450d96d7b3694eccc18e.png

Unicode字符串可以分为三种数据类型

f03073a00eb04c4d9be6cc679e9ca99b.png

二进制字符串可以分为三种数据类型 

4a399754371a4485b74b14de35554cad.png

默认值 

        如果插入行时没有为列指定值,则该列使用默认值。默认值可以是计算结果为常量的任何值, 如常量、内置函数或数学表达式。

        对于表中的每个列,可以指定当用户将该列保留为空白时将在该列中输入的默认值。如果没有 分配默认值,并将该列保留为空白,则:

>如果设置了允许空值的选项,则将向该列中插入NULL。

> 如果没有设置允许空值的选项,则该列将保持空白,但在用户为该列提供值之前,它们将无法保存行。

标识列

        对于每个表,均可创建一个包含系统生成的序号值的标识列,该序号值以唯一方式标识表中的 每行。例如,当在表中插入行时,标识列可自动为应用程序生成唯一的客户回执编号。标识列在其 所定义的表中包含的值通常是唯一的。

        可以使用标识列在表中创建自动递增标识号,所以标识列习惯上又叫自增列,只能为每个表创 建一个标识列。 标识列具有以下三种特点。

     >列的数据类型为不带小数的数值类型。

     >在进行插入(Insert)操作时,该列的值由系统按一定规律生成,不允许空值。

     >列值不重复,具有标识表中每行的作用,每个表只能有一个标识列。

 

创建一个标识列,通常要指定以下三个内容。
 >类型(Type):在SOL Server 2008中,标识列类型必须是数值类型,如decimal、int、numeric. smallint、bigint、tinyint。其中要注意的是,当选择decimal和numeric时,小数位数必须为 零。另外还要注意每种数据类型所表示的数值范围。

>种子(Seed):指派给表中第一行的值,默认为1。

>递增量(Increment):相邻两个标识值之间的增量,默认为1。

 

检查约束

        通过限制列可接受的值,CHECK约束可以强制域的完整性。此类约束类似于FOREIGNKEY约束, 因为可以控制放入列中的值。但是,它们在确定有效值的方式上有所不同:FOREIGNKEY约束从其他 表获得有效值列表,而CHECK约束通过不基于其他列中的数据的逻辑表达式确定有效值。

        可以通过任何基于逻辑运算符返回True 或False的逻辑(布尔)表达式创建 CHECK约束。 

        例如,可以通过创建CHECK约束将age列中值的范围限制为0~150之间的数据,以防止输入的年龄值超出正常的年龄范围。

                逻辑表达式为  “age >=0 and age <=150”

 

视图模式管理表

创建表

        下面将介绍使用SSMS创建数据表的步骤。

案例:某公司需要在名为“class”的数据库中创建表,表名称为"employee”,其中包含列为 编号(int)、姓名(nvarchar(50))、身份证号(varchar(18)).职务(nvarchar(50)).基本工资(money). 备注(nvarchar(2000))。其中,编号自动生成,从1开始,每增加一人则其编号自动加1:要 求输入基本工资的时候,其值必须为0~100000,设置身份证号列为主键。

具体操作步骤如下所述。

(1)打开SSMS,然后展开数据库,右击“表”节点,在弹出的快捷菜单中选择“新建”→ “表”命令。

7741b7309a5f43de976e111e05f58655.png

 

(2)输入第一列的列名为“编号”,数据类型设置为“int",保持“允许NUll值”复选框为默认 的选中状态。

cd387a3ec5d24165a1587238ebeb1856.png

(3)为该列设置标识规范。在“列属性”选项卡中,将“(是标识)”的值改为“是”,“标识增量”和“标识种子”分别设置为“1”,可以发现表的“编号”列的“允许NUll值”复选框被自动清 空,说明标识列自动增量,系统不允许其出现空值。

51855e15dcfb4b008045fa621529f669.png

 (4)分别新建列“姓名”“身份证号”“职务”“基本工资”“备注”。

0c608d2c959b49338e9582cb99055183.png

(5)由于要求输入基本工资的时候,其值必须为0~100000.因此可以在“基本工资”列设置 CHECK约束,即右击“基本工资”,在弹出的快捷菜单中选择“CHECK约束”命令。

477a8fececea4f168c25905e00651466.png

(6)在打开的“CHECK约束”对话框中,单击“添加”按钮,然后在“表达式”右边的文本框 中输入“基本工资>=0 and 基本工资<=100000”,在“(名称)”右边的文本框中修改为“CK_Table_ 基本工资”,确认无误后,单击“关闭”按钮。 

8bfff77a33854170963a1dfe08b7a9c5.jpeg

 (7)右击“身份证号”,在弹出的快捷菜单中选择“设置主键”命令,可将该列设置为主键,主 键列的左边会显示“黄色钥匙”图标。

3af38eb1b99e4e4ea11d0a8f9398bd34.png

(8)设置完成后,保存该表,右击表名,在弹出的快捷菜单中选择“保存”命令,命令保存后在SSMS中可以看到新建完成的表。

c476e38d6f484ad189d0ae419d36ac0e.png

 

 

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/210410.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

探索什么样的导线,适合做433的天线

​​​​​​一、理论基础 (3 封私信 / 18 条消息) 为什么天线的材质会影响接收电磁波的效果&#xff1f; - 知乎 (zhihu.com) 电感基础3——RLC电路&#xff0c;帮助你轻松理解“阻抗”的概念 - 知乎 (zhihu.com) 一文读懂介电性能---介电常数 - 知乎 (zhihu.com) 433MHz 至…

SpringBoot 注入RedisTemplat 启动报错

需求 因为需要限制部门内多个人员同一时间操作同一批客户的需求&#xff0c;考虑下决定用Redis滑动窗口实现自过期以及并发校验。 问题 新建了个Redis工具类封装RedisTemplat 操作&#xff0c;到启动时却发现无法正常启动&#xff0c;报错注入错误。 The injection point has…

利用 EC2 和 S3 免费搭建私人网盘

网盘是一种在线存储服务&#xff0c;提供文件存储&#xff0c;访问&#xff0c;备份&#xff0c;贡献等功能&#xff0c;是我们日常中不可或缺的一种服务。 &#x1f4bb;创建实例 控制台搜索EC2 点击启动EC2 选择AMI 选择可免费试用的 g代表采用了Graviton2芯片。 配置存储 配…

【带头学C++】----- 九、类和对象 ---- 9.5 初始化列表

目录 9.5 初始化列表 9.5.1 对象成员 代码&#xff1a; 9.5.2 初始化列表 9.5 初始化列表 9.5.1 对象成员 在类中定义的数据成员一般都是基本的数据类型。但是类中的成员也可以是对象&#xff0c;叫做对象成员。 先调用对象成员的构造函数&#xff0c;再调用本身的构造函数…

NIO--07--Java lO模型详解

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 何为 IO?先从计算机结构的角度来解读一下I/o.再从应用程序的角度来解读一下I/O 阻塞/非阻塞/同步/异步IO阻塞IO非阻塞IO异步IO举例 Java中3种常见的IO模型BIO (Blo…

C++日常遇到的一些坑的总结

一、const 相关 C中const的不同位置的用法 const 修饰符用法总结 二、函数形参没有变量名 三、指针偏移问题 笔记&#xff1a; 包含来自C标准库的头文件&#xff0c;用#inlcude<xxx>&#xff0c;包含不来自C标准库的头文件&#xff0c;用#include"xxx"最…

Python setup.py 编写

from setuptools import setup, find_packages import atexit import shutilname "sdk"def rm_temp():"""删除打包过程中产生的中间文件:return:"""shutil.rmtree(build)shutil.rmtree({}.egg-info.format(name))# 注册 rm_temp atex…

Hadoop学习笔记(HDP)-Part.18 安装Flink

目录 Part.01 关于HDP Part.02 核心组件原理 Part.03 资源规划 Part.04 基础环境配置 Part.05 Yum源配置 Part.06 安装OracleJDK Part.07 安装MySQL Part.08 部署Ambari集群 Part.09 安装OpenLDAP Part.10 创建集群 Part.11 安装Kerberos Part.12 安装HDFS Part.13 安装Ranger …

链表【2】

文章目录 &#x1f95d;24. 两两交换链表中的节点&#x1f951;题目&#x1f33d;算法原理&#x1f96c;代码实现 &#x1f34e;143. 重排链表&#x1f352;题目&#x1f345;算法原理&#x1f353;代码实现 &#x1f95d;24. 两两交换链表中的节点 &#x1f951;题目 题目链接…

招标新时代:如何利用全国招标投标信息API获取招标投标信息

引言 随着信息技术的迅猛发展&#xff0c;招标投标领域也逐渐步入了数字化、智能化的新时代。全国各地政府和企事业单位纷纷采用先进的招标系统&#xff0c;以提高招标效率、透明度和公平性。在这个背景下&#xff0c;利用全国招标投标信息API成为了获取实时招标投标信息的一种…

写给初学者的 HarmonyOS 教程 -- 状态管理(@State/@Prop/@Link 装饰器)

State 装饰的变量&#xff0c;或称为状态变量&#xff0c;一旦变量拥有了状态属性&#xff0c;就和自定义组件的渲染绑定起来。当状态改变时&#xff0c;UI 会发生对应的渲染改变&#xff08;类似 Compose 的 mutablestateof &#xff09;。 Prop 装饰的变量可以和父组件建立单…

对话式数据需求激增,景联文科技提供高质量多轮对话数据定制采集标注服务

大模型的快速发展使得数据服务需求激增&#xff0c;产品整体处于供不应求状态。对话式数据集成为当下需求热点&#xff0c;人们对于更复杂、更真实的多轮对话数据需求不断增加&#xff0c;定制化服务占据市场需求主流。 通过对多轮对话数据的训练&#xff0c;模型可以更好地理解…

leetcode:225. 用队列实现栈

一、题目 链接&#xff1a;225. 用队列实现栈 - 力扣&#xff08;LeetCode&#xff09; 函数原型&#xff1a; typedef struct { } MyStack; MyStack* myStackCreate() void myStackPush(MyStack* obj, int x) int myStackPop(MyStack* obj) int myStackTop(MyStack* obj) …

Mybatis缓存

:::Mybatis缓存 &#x1f4a1; 根据 遗忘曲线&#xff1a;如果没有记录和回顾&#xff0c;6天后便会忘记75%的内容 读书笔记正是帮助你记录和回顾的工具&#xff0c;不必拘泥于形式&#xff0c;其核心是&#xff1a;记录、翻看、思考 ::: 书名MyBatis缓存机制作者蒂芬崽莫状态…

uniapp设置手机通知权限以及uniapp-push2.0推送

unipush2.0代码 export default function () {// 调用获取用户通知权限setPermissions()// 获取客户端唯一的推送标识&#xff0c;可用于测试uni.getPushClientId({success: (res) > {console.log(res.cid)},fail(err) {console.log(err)}})// 监听推送uni.onPushMessage(r…

珠海市第四届职业技能大赛成功举办,开源网安提供全程技术支持

​近日&#xff0c;由珠海市人社局、珠海市总工会、珠海市教育局、珠海市高新区管委会联合主办的【珠海市第四届职业技能大赛暨第二届“行行出状元”大赛-软件技术竞赛项目】落下帷幕&#xff0c;三位优秀参赛选手脱颖而出&#xff0c;荣获珠海市人社局授予的“珠海市技术能手”…

UE5、CesiumForUnreal实现加载GeoJson绘制多面(MultiPolygon)功能(支持点选高亮)

文章目录 1.实现目标2.实现过程2.1 数据与预处理2.2 GeoJson解析2.3 Mesh构建与属性存储2.4 核心代码2.5 材质2.6 蓝图应用测试3.参考资料1.实现目标 在之前的文章中,基于GeoJson数据加载,实现了绘制单面功能,但只支持单个要素Feature。本文这里实现对Geojson内所有面要素的…

css新闻链接案例

利用html和css构建出新闻链接案例&#xff0c;使用渐变色做出背景色变化 background: linear-gradient(to bottom, rgb(137, 210, 251), rgb(238, 248, 254), white); 利用背景图片&#xff0c;调整位置完成 dd { height: 28px; line-height: 28px; background-image: url(./图…

【Vulnhub 靶场】【Prime (2021): 2】【简单 - 中等】【20210509】

1、环境介绍 靶场介绍&#xff1a;https://www.vulnhub.com/entry/prime-2021-2,696/ 靶场下载&#xff1a;https://download.vulnhub.com/prime-2021/Prime-2.ova 靶场难度&#xff1a;简单 - 中等 发布日期&#xff1a;2021年5月9日 文件大小&#xff1a;3.7 GB 靶场作者&am…

软件平台架构设计与技术管理之道笔记

软件平台架构设计与技术管理之道笔记 认知 领导软件平台各方面的工作&#xff0c;对技术底蕴、思维模式、决策能力、工作风格、文化铸造等方面都有极高的要求&#xff0c;可以称之为“领域智慧”。认知盲区的代价是巨大的&#xff0c;“不知”比“不会”的后果更严重&#xf…