sql基础知识(SQL基础知识梳理)
本篇文章给大家谈谈sql基础知识,以及SQL基础知识梳理对应的知识点,希望对各位有所帮助,不要忘了收藏本站喔。
本文目录一览:
SQL数据库是什么? 主要干什么用的 ?
数据库当然就是老者用来存储数据的
只不过访问和查询比较快
SQL是一种数据库描述语言
实际也就是程序语言
在主侍好薯流编程语言中均支持
数据库管理软件主要有微软的MS
SQL,
Orcal,DB2,和MySQL
语法相似
最袜旁好学MySQL
因为现在php比较流行
而php+MySQL+Alpha是主流的建站选择
[img]SQL重点知识
根据模型应用目的的不同,数据模型可以分为两类:一类是概念模型,是按用户的观点来对数据和信息进行抽象;另一类是结构数据模型,是按计算机的观点建模。
结构数据模型直接描述数据库中数据的逻辑结构,常用的结构数据模型有层次模型、网状模型、关系模型、面向对象模型
触发器有三种类型,即INSERT类型、UPDATE类型、DELETE类型
如果要计算表中的行数,可以使用聚合函数COUNT( )
向表中添加数据应使用INSERT命令,更新数据库UPDATE命令
数据库的类型有四种分别为:数据库备份、事务日志备份、差异备份、文件和文件组备份
DTS是指数据转换服
为了实现安全性,每个网络用户在访问SOL数据库之前,都必须经过两个阶段的检验:身份验证和权限验证,其中身份验证分为Windows验证模式和混合验证模式
全局变量的名称以@@字符开始,局部变量以@字符开始
数据库的还原模型分别是简单还原,完全还原,批日志还原
行注释的符号为 , ;块注释的符号位 /**/ , 角色 是将用户组成一个集体授权的单一单元
使用索引可以减少检索时间,根据索引的存储结构不同分为:簇集索引和非簇集索引
命令truncate table的功能是清空数据库
权限分为对象权限,语言权限,隐含权限
求最大值的函数是MAX,最小值是MIN
数据完整性可以分为实体完整性、值域完整性、引用完整性、用户自定义完整性,其中主键可以实现实体完整性
模糊查询符号%代表任意字符查询条件
实现数据完整性的途径有约束、默认、规则、存储过程
数据库系统的特点分别是数据库的结构化、数据共享、数据独立性、数据可控冗余度
在表中,主键是指表中的某一列,该列的值唯一表示一行
SQL文件包括:数据文件(.mdf或者.ndf)和日志租消文件
数据库管理系统,简称DBMS,它是指帮助用户建立、使用、和管理数据库的软件系统
DB:数据库
DBA:数据库管理员
修改某备迟张表的结构使用的关键字是ALTER,修改表中数据用UPDATE
事物的操作必须具备以下四个属性:原子性,一致性,隔离性,永久性
索引的顺序和数据表的物理顺序相同的索引是聚集索引
备份数据库的两种方式是备份数据库和备份事务日志
差异备份只记录自上次完整数据库备份后发生更改的数据
所有的数据库都有一个主数据文件和一个或多个事物日志文件,此外,还可能有次要数据文件
SQL服务包括有主服务、代理服务、…
SQL有两类数据库:系统数据库和用户数据库
索引类型分为:唯一索引、簇集索引和非簇集索引
SQL中编程语言是Transact-sql
在SELECT语句的FROM子句中最多可以指定256个表或视图,相互之间要用逗号分隔
数据库管理系统的数据语言分为:DDL,DML,DCL,
创建数据库的语言是create database,修改数据库的语言是alter database
用户对数据进行添加、修改、和删除时,自动执行的存储过程为触发器
索引是对数据库表中一列或多列的值进行排序的一种结构,使用索引可快速访问数据库表中的特定信息。
视图是虚表,是从一个或几个基本表(或视图)中导出的表,在系统的数据字典中仅存放了视图的定义,不存放视图弊滚知对应的数据。
存储过程是一组为了完成特定功能的SQL语句集,经编译后存储在数据库中。用户通过指定存储过程的名字并给出参数(如果该存储过程带有参数)来执行它。存储过程是数据库中的一个重要对象,任何一个设计良好的数据库应用程序都应该用到存储过程。
什么是SQL数据库
SQL是Structured
Quevy
Language(结构化查询语言)的缩写。SQL是专为数据库而建立的操作命令集,是一种功能齐全的数据库语言。在使用它时,只需要发出“做什么”的命令,“怎棚并宴么做”是不用使用者考虑的。SQL功能强大、简单易学、使用方便,已经成为了数据链银库操作的基础,并且现在几乎所有的数据库均支持SQL。
##1
二、SQL数据库蔽首数据体系结构
SQL数据库的数据体系结构基本上是三级结构,但使用术语与传统关系模型术语不同。在SQL中,关系模式(模式)称为“基本表”(base
table);存储模式(内模式)称为“存储文件”(stored
file);子模式(外模式)称为“视图”(view);元组称为“行”(row);属性称为“列”(column)。名称对称如^00100009a^:
SQL Server 连接基础知识
引言
该堆栈的顶部是 API 或对象库层 应用程序通过对象库公开的 API 函数或接口连接到 Microsoft? SQL Server 用于访问 SQL Server 的 API 示例包括 ODBC 和 DB Library 用于访问 SQL Server 的对象库示例包括 OLE DB ADO 和 ADO NET 由于 ADO 最终使用 OLE DB 与服务器通信 因此 Windows 应用程序在与 SQL Server 通信时实际上只使用两个常用的对象库 即 OLE DB 和 ADO NET 由于通过 ADO 或 ADO NET 进行连接通常比通过 ODBC 进行连接更普遍(但 SQL Server 的查询分析器和企业管理器仍通过 ODBC 进行连接) 因此本文将从 ADO/OLE DB 和 ADO NET 的角度介绍 SQL Server 连接体系结构的客户端 如今 大多数应用程序均通过对象库(而非 ODBC 或类似 API)连接到 SQL Server
ADO 和 OLE DB
OLE DB 客户端(也称作使用者)通过客户端提供程序与服务器以及其他后端程序进行通信 此提供程序是一组 组件(一个或多个) 用于将应用程序请求转换为网络进程间通信 (IPC) 请求 在使用 SQL Server 的情况下 最常用的 OLE DB 提供程序是 SQLOLEDB 它饥漏是 Microsoft 为 SQL Server 提供的 OLE DB 提供程序 SQLOLEDB 随附于 SQL Server 中 并作为 Microsoft 数据访问组件 (MDAC) 库的一部分安装
为了使用 ADO 与 SQL Server 进行通信 应用程序首先使用 Connection 对象建立与服务器的连接 ADO 的 Connection 对象接受一个连接字符串 该字符串指定要使用的 OLE DB 提供程序以及传递给它的参数 如果应用程序使用 SQLOLEDB 提供程序连接到 SQL Server 则该字符串中将显示 SQLOLEDB
ADO 应用程序还可以通过 ODBC 连接到 SQL Server 为此 应用程序将使用适用于 ODBC 的 OLE DB 提供程序 并指定在其连接字符串中引用目标 SQL Server 的 ODBC 数据源 这种情况下 应用程序与 OLE DB 进行通信 同时 ODBC 的 OLE DB 提供程序调用相应的 ODBC API 以便与 SQL Server 进行会话
ADO NET
ADO NET 应用程序通常使用 NET Framework Data Provider for SQL Server 连接到 SQL Server 该本机提供程序使 ADO NET 对象能够与 SQL Server 直接进行通信 通常 应用程序使用 SqlConnection 对象建立连接 然后使用 SqlCommand 对象向服务器发送命令 并接收服务器返回的结果 SqlDataAdapter 和 SqlDataReader 类通常与 SqlCommand 一起使用 以便通过托管的代码应用程序与 SQL Server 进行交互
通过 OleDbConnection 类 ADO NET 应用程序还可以使用 SQLOLEDB OLE DB 提供程序与 SQL Server 进行交互 此外 它们可以通过 OdbcConnection 类使用 ODBC 访问 SQL Server 因此 仅通过托管代码 您就有三种不同的方法从应用程序访问 SQL Server 从故障排除的角度而言 了解这些方法是非常有用的 因为它可以帮助您将遇到的与连接相关的问题归结到特定的数据访问层或库
客户端 Net Library
该堆栈中的下一层是 Net Library Net Library 在 API 或对象库(应用程序使用它与 SQL Server 进行通信)与网络协议(用于与网络交换数据)之烂镇烂间旅粗提供了一个通道 SQL Server 为所有主要的网络协议提供了 Net Library 这些库以透明方式将客户端发出的请求发送到 SQL Server 并将服务器发出的响应返回给客户端 可以使用 SQL Server 的客户端网络实用程序配置适用于特定客户端的 Net Library 支持的客户端协议包括 TCP/IP 命名管道 NWLink 多协议 (RPC) 和其他一些协议
尤其值得一提的 Net Library 是共享内存 Net Library 顾名思义 该 Net Library 使用 Windows 的共享内存功能在 SQL Server 客户端与服务器之间进行通信 显然 这意味着客户端与服务器必须位于同一台物理计算机上
由于它能够绕过物理网络堆栈 因此共享内存 Net Library 要比其他 Net Library 快得多 对共享内存区域的访问受到同步对象的保护 因此客户端与服务器之间的通信速度主要受限于 Windows 对内核对象进行调度的能力 以及进程与共享内存区域之间进行数据复制的能力
可以在连接时将某个时间段或(本地)指定为您的计算机名 来指示使用共享内存 Net Library 也可以在连接时为计算机\实例名加上前缀 lpc: 来指示要使用共享内存 Net Library
注意 即使连接到同一台计算机上的 SQL Server 共享内存 Net Library 也未必就是最佳的连接选项 在某些情况下 客户端与服务器之间的直接连接可能限制它的扩展性 与应用程序整体体系结构中的其他元素一样 应始终对给定技术解决方案进行全面的测试 然后才能判断它是否有良好的扩展性以及是否比其他方法更快
连接
客户端进行连接时 SQL Server 的用户模式计划程序 (UMS) 组件将它指定给特定的计划程序 启动时 SQL Server 为系统上的每个 CPU 创建一个单独的 UMS 计划程序 当客户端连接到服务器时 这些客户端将指定给具有最少连接数的计划程序 连接后 客户端将不会更换计划程序 它将始终受到指定计划程序的控制 直到连接断开
这对与服务器建立多个连接的应用程序很重要 如果应用程序性能较差 或无法在它的多个连接上平均分配工作 则在该应用程序的某些连接之间可能造成不必要的 CPU 资源争用 而其他连接实际上却处于空闲状态
例如 应用程序与双处理器计算机上运行的 SQL Server 建立了四个连接 连接 和 隶属于处理器 连接 和 隶属于处理器 如果应用程序的大部分工作通过连接 和 执行 则这两个连接将争用 CPU 而 CPU 实际上可能仍处于空闲状态 这种情况下 应用程序只能断开某些连接或重新连接某些连接 并希望连接 和 隶属于不同的 CPU (连接时无法指定处理器隶属关系) 或在它的连接上重新分配工作负荷 以便每个连接的工作负荷更加均衡 当然 后一种情况要远好于前一种情况
连接内存
SQL Server 为客户端请求的每个连接保留三个数据包缓冲区 每个缓冲区的大小取决于 sp_configure 存储过程指定的默认网络数据包大小 如果默认网络数据包大小小于 KB 则这些数据包的内存将由 SQL Server 的缓冲池提供 否则 该内存将由 SQL Server 的 MemToLeave 区域分配
值得一提的是 NET Framework Data Provider for SQL Server 的默认网络数据包大小为 KB 因此 与托管代码客户端连接关联的缓冲区通常由 SQL Server 的 MemToLeave 区域提供 而典型的 ADO 应用程序却不同 它们的默认数据包大小为 KB 因此缓冲区将由 SQL Server 缓冲池分配
事件
连接后的客户端请求通常分为两种广泛类别 语言事件和远程过程调用 尽管还存在其他类别 但大多数由 SQL Server 客户端发送到服务器的请求由以下两种类型之一构成 语言事件是从客户端发送到服务器的 一组 T SQL 例如 如果调用 ADO Command 对象(其 CommandText 属性设置为 T SQL 查询 CommandType 属性设置为 adCmdText)的 Execute 方法 则查询将作为语言事件提交给服务器 同样 如果将 CommandType 设置为 adCmdTable 并调用 Execute 方法 则 ADO 将生成一个内部查询(它将选择 CommandText 属性标识的表中的所有列) 并将它作为语言事件提交给服务器 另一方面 如果将 CommandType 设置为 adStoredProc 则调用 Execute 将使 ADO 向服务器提交一个远程过程调用请求 以执行 CommandText 属性中列出的存储过程
为何要关心将请求作为语言事件还是作为 RPC 提交给服务器呢?通常 这是因为 RPC 的功能更为出色 特别是在重复调用具有不同筛选值的同一查询时 尽管 SQL Server 可以自动将普通的语言事件请求参数化 但这种能力非常有限 它从不尝试自动将某些类型的查询参数化 这可能会导致基本相同的查询产生不同的执行 从而只因为这些不同的执行提供不同的值 而导致在服务器上白白浪费计划编译的成本 这通常不是您所希望的结果 您希望针对查询的第一次执行编译一个新的计划 然后将该计划重复用于具有不同参数的执行
而 RPC 则通过显式参数化查询(而不是依赖服务器参数化查询)来支持计划重复使用 为过程的第一次执行生成一个计划后 随后的执行将自动重复使用该计划 即使它们提供的参数值不同 与通过语言事件调用存储过程相比 使用 RPC 调用存储过程不仅节省了计划编译所需的执行时间和 CPU 资源 还增强了 SQL Server 内存资源的利用率 因为它避免了冗余执行计划所浪费的内存
在执行动态 T SQL 时 通常首选 sp_executesql 而不是 EXEC() 也出于同样的原因 Sp_executesql 的工作方式是 使用指定的查询创建一个存储过程 然后使用提供的参数调用它 与 EXEC() 不同 sp_executesql 提供了一个允许您参数化动态 T SQL 并支持计划重复使用的机制 使用 sp_executesql 执行的动态查询比使用 EXEC() 的查询能够在更大程度上避免不必要的编译和资源消耗
TDS
从客户端发送到 SQL Server 的 RPC 语言事件和其他类型的请求被格式化为称作表格数据流 (TDS) 的 SQL Server 特定数据格式 TDS 是 SQL Server 客户端和服务器之间使用的 语言 对于它的确切格式将不作介绍 但是 如果客户端要与 SQL Server 进行通信 就必须使用 TDS
目前 SQL Server 支持三种版本的 TDS TDS (适用于 SQL 客户端) TDS (适用于 SQL Server 客户端)和 TDS (适用于 SQL Server 和 客户端) 完全支持所有 SQL Server 功能的版本只有 TDS 其他版本保持向后兼容
服务器端 Net Library
关于sql基础知识和SQL基础知识梳理的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。