一般的 DBA 可能会觉得他们好像在盯着一个黑匣子,只是等待和刷新,直到数据库完成恢复。下面分享一个更简单的方法!...◆ 二、解决方案 您知道 SQL Server 的 ERRORLOG 实际上会计算自己的估计值吗?...日志条目有时可能会让人不知所措且过于详细,因此我们将使用一个简单的 SQL 查询来生成易于阅读且令人惊讶的准确估计结果。 我们将从以下查询开始。...请务必将数据库设置为“master”,并将第一行中的变量“@DBName”替换为您要调查的数据库。如果需要,您还可以修改此查询以包含更多的结果(例如“SELECT TOP 10”)。...感谢您对IT大咖说的热心支持!
变量的分类 局部变量:(仅在过程中使用) 局部变量必须标记@作为前缀,如@age。 局部变量的使用也是先声明(使用declare),再赋值。...局部变量定义与赋值 局部变量的定义语法 DECLARE @变量名 数据类型 赋值方法 SET @变量名 = 值 或 SELECT @变量名 = 值 使用select赋值确保筛选出的记录只有一条...场景示例 下面以一个场景来使用定义变量,有如下的一个表结构,表名称为Students,现在要查询李铭及其学号相邻的学员。...最后一个T-SQL错误的错误号 @@IDEENTITY 最后一次插入的标识值 @@LANGUAGE 当前使用的语言的名称 @@MAX_CONNECTIONS 可以创建的同时连接的最大数目 @@ROWCOUNT...受上一个SQL语句影响的行数 @@SERVERNAME 本地服务器的名称 @@TRANSCOUNT 当前连接打开的事务数 @@VERSION SQLServer的版本信息
前言 在做项目的过程中,有时同一个操作会同时对数据库中的两张表进行操作,比如在机房收费系统中,下机需要把下机记录更新到下机表中,同时又要更新卡表中的余额,如果在操作数据库的过程中出现错误,只对其中的某一张表进行了操作...定义 事务(Transaction)是并发控制的基本单位。所谓的事务,它是一个操作系列,这些操作要么都执行,要么都不执行,它是一个不可分割的工作单位。...同时,并行事务的修改必须与其他并行事务的修改相互独立。 持久性(Durability):事务完成之后,它对于系统的影响是永久的,真是修改了数据库。...语法 BEGIN TRAN:开始事务,设置事务的起始点。 COMMIT TRAN:提交事务,使事务成为数据库中永久的、不可逆转的一部分。...; END 事务可以设置在程序的代码中,也可以写在数据库的脚本中,下面是一个事务和存储过程结合使用的例子 ALTER PROCEDURE [dbo].
一.sql server连接的验证方式 分为两种: Windows 身份认证: 使用windows的用户名密码验证 SQL Server 身份认证 : 使用sql server的用户名 + 密码的方式登录...SQL Server 身份认证 (一般情况下都会使用这种验证方式而不是windows验证) 配置支持远程连接 (否则不支持远程连接) 修改SA账号密码并启用(sa用户为内置的账号,一般使用这个账号连接sql...打开ssms 打开后采用默认的windows验证先连接上sql server 配置验证方式以及”支持远程连接” 修改sa账号的密码并启用 三.使用Navicat工具连接Sql...,习惯了,所以一般比较喜欢用navicat连接并操作数据库 使用navicat 连接sql server需要先安装sql server 驱动,否则连接时会报错找不到驱动 在navicat的安装目录下找到...sqlserver的驱动双击安装即可 现在我们就可以连接Navicat了,需注意的是连接名后面需要使用半角的逗号去指定端口,而mysql则不需要,算是一个坑吧,sql server默认的端口为1433
一、SQL Server 数据库备份简介 1、SQL Server Management Studio 简介 SSMS 全称 " SQL Server Management Studio " , 是 由...Microsoft 开发的一款集成式环境 , 用于管理 Microsoft SQL Server 的数据库 ; SSMS 是 SQL Server 的主要管理工具之一 , 提供了丰富的功能和工具 ,...帮助开发人员和数据库管理员进行数据库管理、查询、优化和开发工作 ; 本篇博客介绍如何使用 SSMS 进行数据库备份 ; 使用的原理是 将数据库中的 数据 生成为 SQL 脚本 ( 几万条 SQL 语句...; 仅限架构 : 指的是 生成 建表的 SQL 语句 ; 仅限数据 : 指的是 生成 插入数据的 SQL 语句 , 执行前要删除数据库中的对应表 , 使用 TRUNCATE TABLE table_name...; 等待数据库表 生成脚本即可 ; 生成完毕后 , 点击 完成 按钮 ; 如果使用 固态硬盘 , 上述操作 几秒 就可以完成 , 如果使用机械硬盘 , 可能需要几分钟 ; 在保存位置 查看生成的脚本
大家好,又见面了,我是你们的朋友全栈君。 DATEADD日期函数 DATEADD() 函数在日期中添加或减去指定的时间间隔。...number 是您希望添加的间隔数;对于未来的时间,此数是正数,对于过去的时间,此数是负数。...datepart 参数可以是下列的值: datepart 缩写 年 yy, yyyy 季度 qq, q 月...如果,您希望更容易地发现我的新博客,不妨点击一下,【关注我】 如果,您希望给我更多的鼓励,不妨在右侧点击,【打赏一下】 博文是自己对学习成果的总结,学习总结知识-》分析问题-》解决问题。...文中存在的观点/描述不正确的地方,欢迎指正。 感谢您的阅读,如果您对我的博客所讲述的内容有兴趣,请继续关注我的后续博客,我是yxtic 。
SQL Server 自 2008 版起引入了 uniqueidentifier 字段,它存储的是一个 UUID, 或者叫 GUID,内部存储为 16 个字节。...SQL Server 可用两个函数来生成 uniqueidentifier, 分别是 NEWID() 和 NEWSEQUENTIALID(), 后者只能用作字段的默认值。...SQL Server 的 uniqueidentifier 类型字段表明了内部如何存储,在我们操作它时,它的外在表现形式都是一个固定格式 xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx...本文所使用的 SQL Server 是 2017 版,通过 Docker 来启动的 docker run -e ‘ACCEPT_EULA=Y’ -e ‘SA_PASSWORD=yourStrong(!...Password’ -p 1433:1433 -d microsoft/mssql-server-linux:2017-latest 然后我们创建一个带有 uniqueidentifier 类型字段的表
之前很羡慕MySQL 有这样的工具可以把数据库里的数据导成脚本,SQL Server 2005 的时候大牛Pinal Dave写了个Database Publishing Wizard,具体用法参考他写的文章...SQL SERVER – 2005 – Generate Script with Data from Database – Database Publishing Wizard。...SQL Server Management Studio 2008现在已经自带了这样的功能,下面我就来演示下如何使用: 1、打开SQL Server Management Studio 2008 ,连接到你的数据库服务器...3、右击选中的数据,按照以下路径选择生成脚本向导 :AdventureWorks -〉任务 -〉生成脚本 ? 4、当点击生成脚本,弹出一个向导--生成数据库对象脚本: ?...5、下一步到达设置脚本编写选项,进入高级设置对话框,关键是要编写脚本的数据类型这里,默认是仅限架构,选择架构和数据或者是数据都可以吧数据导成脚本: ? 执行完就可以看到如下的结果了 ?
大家好,又见面了,我是你们的朋友全栈君。...–函数QUOTENAME –功能:返回带有分隔符的Unicode 字符串,分隔符的加入可使输入的字符串成为有效的Microsoft SQL Server 2005 分隔标识符。...) –举例说明: –比如你有一个表,名字叫index –你有一个动态查询,参数是表名 declare @tbname varchar(256) set @tbname=’index’ —查这个表里的数据...: print(‘select * from ‘+@tbname) exec(‘select * from ‘+@tbname) –这样print出来的数据是 select * from index –...–结果:select * from [index] exec(‘select * from ‘+QUOTENAME(@tbname)) –结论 /* 初步理解为解决有些对象是SQLSERVER关键字的情况
SQL Server 数据库中除了能执行基本的SQL语句外,也可以执行Shell脚本。默认安装后,SQL中的Shell脚本的功能是关闭的,需要手动打开, 执行以下脚本即可打开该功能。...在SQL Server查询分析器中执行以下脚本: --判断临时表是否已经存在 IF OBJECT_ID('tempdb.....TABLE #TempTable;--删除临时表 END --创建临时表 CREATE TABLE #TempTable ( Size varchar(8000) ) --执行shell脚本并将结果插入临时表中
首先,所有必要地执行串行计划SQL代码已经存在并且已经被优化多年和在线发布。其次,方法的方位很合适:如果更多线程被调用,SQLServer 能轻易添加额外计划分之来分配更多线程。...不及时纠正,计划就会产生错误的结果集并且和可能花费更多时间。手工并行的例子通过使用where子句来避免这个问题。 ...交换操作符使用缓存来减少开销,并且为了实现控制基本种类的流(例如为了阻止快速生产者比慢速消费者快太多)。...轮循 每个新的行按照固定的序列被发送给下一个消费者 广播 每一行被发送给所有消费者。 请求 每一行被发送给第一个请求的消费者。这是仅有的通过消费者内部的交换符拉出行的分割类型。...在计划中输入的行已经排序的时候对后面的操作符是很有用的(沿用开始的排序,或者作为一个从索引中读取的已经排序的序列)。
table tmp_cup ( a varchar(20), b varchar(50), c varchar(20) ) select * from t_customer --//更新简称字列...update t_customer set SHORTNAME=(select shortname from tmp_cup where a=custid) 不过如此的话, 如果子查询的某个查询返回多条数据的话就有可能报错...:消息 512,级别 16,状态 1,第 1 行 子查询返回的值不止一个。...=、、>= 之后,或子查询用作表达式时,这种情况是不允许的。
动态管理视图 (DMV) 和动态管理函数 (DMF) 返回的服务器状态信息可用于监控服务器实例的运行状况、诊断问题和优化性能。.../输出 此部分介绍为监控 SQL Server 运行状况而针对这些动态管理视图和函数运行的一些常用查询。...CPU 总使用率(带 SQL 文本)。...desc 如果已检测到过多的编译或重新编译,请尽可能多地收集相关数据并将其报告给规划支持人员 内存瓶颈 开始内存压力检测和调查之前,请确保已启用 SQL Server 中的高级选项。...获取 SQL Server 平稳运行时性能计数器和主要 DMV 查询输出的基线非常重要。 这些 wait_types 可以指示您的 I/O 子系统是否遇到瓶颈。
phoenix自带了执行sql脚本的功能,这样方便了希望能够直接将一些关系型数据库的数据进行迁移到Hbase(也可以直接使用sqoop进行导入)。...在【PHOENIX_HOME】目录下创建user.sql,内容如下: -- create table user create table if not exists user (id varchar primary...id, account, passwd) values('003', 'zx', 'zx'); -- query data select * from user;在【PHOENIX_HOME】目录下执行脚本.../bin/psql.py 192.168.187.128,192.168.187.129,192.168.187.130:2181 user.sql
关于PIVOT运算符的使用,请参考:SQL server 2005 PIVOT运算符的使用。...IN ([UnpivotedCol1],[UnpivotedCol1],[UnpivotedCol3],etc..) ) AS Alias 二、UNPIVOT的使用例子... 我们使用了SQL server 2005 PIVOT运算符的使用文章中的例子。...NULL,即没有订单,使用UNPIOVT后忽略掉了NULL值。...PIVOT运算符的使用,请参阅:http://blog.csdn.net/robinson_0612/archive/2010/03/16/5385117.aspx
PIVOT,UNPIVOT运算符是SQL server 2005支持的新功能之一,主要用来实现行到列的转换。...本文主要介绍PIVOT运算符的操作,以及如何实现动态PIVOT的行列转换。 关于UNPIVOT及SQL server 2000下的行列转换请参照本人的其它文章。...: ● 用于生成pivot数据源的源表,作为一个输入表 ● pivot表 ● 聚合列及透视列的选择 TSQL中pivot的实现: 1->上例中Orders表相当于是一个输入表...Year是透视列,用于生成维度。 pivot首先将聚合列之外的列进行分组,并对其实现聚合。...,数据来源于SQL server 2005的AdventureWorks,其实现的原理同上。
SQL Server中SET QUOTED_IDENTIFIER的使用 在存储过程中经常会有 SET QUOTED_IDENTIFIER on SET QUOTED_IDENTIFIER off...那是因为distinct是sqlserver的标识符,如果想以distinct为表时,在QUOTED_IDENTIFIER为off的情况下,是不能创建表名为distinct的表的,因为在QUOTED_IDENTIFIER...为off情况下,sqlserver的标识符是不允许加引号的,所以在 SET QUOTED_IDENTIFIER off的情况下,不管distinct加引号或不加引号或加双引号都是不可以的。...但是在 SET QUOTED_IDENTIFIER on 的情况下是可以把sqlserver的标识符加上双引号来创建以sqlserver标识符为表名的表,但是加单引号也是不可以的。...当 SET QUOTED_IDENTIFIER 为 OFF 时,标识符不可加引号,加了引号也没有用,且必须符合所有 Transact-SQL 标识符规则。
在文章中,我们写一个 shell 脚本,它在 crontab 中指定固定时间间隔监控磁盘使用情况,并在报告达到指定的阈值时通过电子邮件发送报告。...测试磁盘使用情况的脚本 以下是测试磁盘使用情况并将报告发送到指定邮箱的脚本。脚本的解释在代码片段之后给出。 [root@localhost ~]# vim disk-monitor.sh #!...环境变量MAILID保存必须在其中发送报告的邮箱地址。 VALUE 保存要设置的阈值。 SERVERNAME 保存服务器的主机名,用于电子邮件通知中的服务器标识。...监控脚本执行 下面需要修改一下disk-monitor.sh脚本的权限,为它添加可执行权限: [root@localhost ~]# chmod +x disk-monitor.sh 使用下面方式运行脚本...总结 在文章中我们写了一个 shell 脚本,它在 crontab 中指定固定时间间隔监控磁盘使用情况,并在报告达到指定的阈值时通过电子邮件发送报告。
前言 前一篇《SQL Server中With As的介绍与应用(一)--With As的介绍》我们介绍了一下SQL中With As,在With As中还可以进行递归的调用,这一篇我们就来讲讲递归的使用。...代码演示 一般我们使用递归的方式都是通过UNION ALL的方式,在UNION ALL 下面可以直接引用我们定义的with as的名称,如下: ?...这就可以看出来,其实with as的递归方式还是很简单的,只要理解了UNION ALL上面的语句直接可以引用即可。 ---- 接下来我们把刚才这个取数改一下,变为我们要得到100以内的奇数。...实现我们取余数并且加入判断这里我们就用到了sql中的case when XXX then XXX else YYY end 我们直接贴出来代码 declare @count int select @count...,最终实现的效果如下图: ?
二、实验原理 1、 使用CREATE TRIGGER语句定义触发器,ALTER TRIGGER语句修改触发器,DROP TRIGGER语句删除触发器。...如果触发语句对应的表上有完整性约束,这些完整性约束必须不违背时,相应的触发语句才能执行,然后才能触发对应的AFTER/FOR类型的触发器。...4、 SQL SERVER为每个触发器都创建了两个临时表INSERTED表和DELETED表,这两个表的逻辑结构与被触发器作用的表一样,用户可以读取这两个表的内容,但不能对它们进行修改,触发器执行完后,...当执行INSERT时,INSERTED表中保存要向表中插入的所有行;当执行DELETE时,DELETED表中保存要从表中删除的所有行;当执行UPDATE时,修改前的行保存在DELETED表中,修改后的行保存在...三、实验设备 安装有SQL SERVER 2000的计算机。 四、实验示例 1、写一个允许用户一次只删除一条员工记录的触发器。
领取专属 10元无门槛券
手把手带您无忧上云