SqlServer

SQL Server提高并发查询效率

同事写了个程序用创建多个线程使用ado同时对同个数据库进行相同的查询,涉及2张数据表的联查。当线程数非常多的情况下,读取数据的效率就会变得很慢,例如50个线程同时查询大概3000条数据,查询完成后通过游标全部读取到本地需要大概30秒。单个线程可能就一两秒。这是由于数据库锁导致的。同样的程序在我的机子上运行性能提高了1倍。主要原因由于我连接的sqlserver是企业版的,而同事那个连接的数据库是开发版的,企业版的sqlserver对并发访问做了一定的优化。但

系统 2019-08-12 01:51:51 2568

SqlServer

SQL Server管理员专用连接的使用

原文:SQLServer管理员专用连接的使用作为一名DBA,经常会处理一些比较棘手的服务无响应问题,鉴于事态的严重性,多数DBA可能直接用“重启”大法,以便尽快的恢复生产环境的正常运转,但是多数情况下我们却无法究其原因,即使产生了dump文件,没有微软的支持,我们同样被蒙在鼓里,幸好微软给我们留了一条“后路”,供我们在SQL服务无法连接时,使用它连接并查看“病因”,那就是DAC,dedicatedadministratorconnection,管理员专用连

系统 2019-08-12 01:54:46 2567

SqlServer

SQL Server 2005 MD5函数

原文:SQLServer2005MD5函数在SQLServer2005下自带的函数HashBytes(),此函数是微软在SQLServer2005中提供的,可以用来计算一个字符串的MD5和SHA1值,使用方法如下:--获取123456的MD5加密串selecthashbytes('MD5','123456');--获取123456的SHA1加密串selecthashbytes('SHA1','123456');有了这个函数可以在SQLServer中为字符串

系统 2019-08-12 01:53:25 2567

SqlServer

SQL server 2005 切换分区表

如转载,请注明出处:http://blog.csdn.net/robinson_0612/archive/2009/11/10/4794371.aspxSQLserver2005切换分区表在日常工作中经常需要用到分区表切换的问题,笔者在此列出几种常见的分区表切换的问题,供参考。一、分区表的切换无外乎以下三种形式:1.将一个分区中的数据切换成单个表。2.将表作为分区切换到已分区的表中。3.将分区从一个已分区表切换到另一个已分区表。二、切换分区表的主要手段:A

系统 2019-08-12 01:52:41 2567

SqlServer

SQL Server 找回没有备份的数据

问题:有一个库,做的是全备份+日志备份,在2011年3月8日,14点产生一次全备份,在14:10分产生日志备份,在14:12分down机,请问怎么能恢复14:10到14:12分中的这段数据(前提,前期日志备份全部正确可用),机器硬盘完好。使用方法:1.如果数据库已经损坏如果数据库已经损坏,可以使用backuplog{数据库名}to{磁盘逻辑地址}withno_truncate备份数据库。因为可能存在对受损数据库备份日志尾部时,日志备份中正常捕获的部分元数据

系统 2019-08-12 01:32:21 2567

SqlServer

SQL server 经验分享(四):查询中增加序号列

语句:selectrowid=identity(int,1,1),*into#tempfrom表名select*from#temp举例:原始数据:数据库为mydata,表名为:刊名语句:selectrowid=identity(int,1,1),*into#tempfrom[mydata].[dbo].[刊名]select*from#temp结果:SQLserver经验分享(四):查询中增加序号列

系统 2019-08-29 22:37:47 2566

SqlServer

Sql Server 中一个非常强大的日期格式化函数

SelectCONVERT(varchar(100),GETDATE(),0):0516200610:57AMSelectCONVERT(varchar(100),GETDATE(),1):05/16/06SelectCONVERT(varchar(100),GETDATE(),2):06.05.16SelectCONVERT(varchar(100),GETDATE(),3):16/05/06SelectCONVERT(varchar(100),GETD

系统 2019-08-12 01:54:50 2564

SqlServer

SQL Server数据库开发规则

一、了解你用的工具不要轻视这一点,这是我在这篇文章中讲述的最关键的一条。也许你也看到有很多的SQLServer程序员没有掌握全部的T-SQL命令和SQLServer提供的那些有用的工具。“什么?我要浪费一个月的时间来学习那些我永远也不会用到的SQL命令???”,你也许会这样说。对的,你不需要这样做。但是你应该用一个周末浏览所有的T-SQL命令。在这里,你的任务是了解,将来,当你设计一个查询时,你会记起来:“对了,这里有一个命令可以完全实现我需要的功能”,于

系统 2019-08-12 01:32:40 2562

SqlServer

SQL Server安装问题 mof 编译器无法连接到wmi服

方法1.出现错误后,找到注册表的"HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\SessionManager"并将其下面的"PendingFileRenameOperations"的值删掉。然后重新运行安装。方法2.在创建窗口句柄之前,不能在控件上调用Invoke或BeginInvoke。原因是,VC2010的一个服务程序mscorsvw.exe进程调用Invoke导致的,结束这个进程,即可。方法3

系统 2019-08-12 01:54:32 2561

SqlServer

安装SQL Server 2005 - 初学者系列 - 学习者系

初学者阶段,建议从数据库为基础入手进行学习。下面介绍微软的SQLServer2005数据库的安装。首先,从下列地址获取SQLServer2005的安装程序。ed2k://|file|cs_sql_2005_ent_x64_dvd.iso|1019222016|10FD11133A3E70DAD665BEDC1090AD28|/开始安装1、选择许可2、检查兼容性3、输入默认系统姓名4、这里把下面的选项也选上5、这里选择混合模式,并输入sa登录账号的密码6、开

系统 2019-08-12 01:54:12 2560

SqlServer

SQLSERVER PRINT语句的换行

原文:SQLSERVERPRINT语句的换行SQLSERVERPRINT语句的换行想在输出的PRINT语句里面换行,可以这样做/*SQL的换行制表符CHAR(9)换行符CHAR(10)回车CHAR(13)*/PRINT'Test'+CHAR(13)+'Name'PRINT'Test'+CHAR(10)+'Age'PRINT'Test'+CHAR(9)+'Tel'--以文本格式显示结果SELECT'AAA'+CHAR(10)+'BBB'--AAABBBSEL

系统 2019-08-12 01:33:15 2560

SqlServer

Perl 连接 SQL Server(ReShip)

准备工作:用到的perl扩展组件(modules)在上篇贴出.(win32::odbc模块)下载组件后按照Readme文件安装倒响应目录.配置好相应的odbc数据源.程序实现:使用useWin32::ODBC;语句包含应使用的模块是win32::odbc写出数据库连接字符串$DSN="DSN=MyDSN;UID=sa;PWD=password"然后就可以建立相应的连接$data=newWin32::ODBC($DSN)#new一个连接对象这样就建立了和数据

系统 2019-08-12 01:55:23 2559

SqlServer

T-SQL 创建表- 修改表默认字段数值 SQL SERVER

在一个SQLServer数据库中,可以创建多达两万亿个表输入一条CreateTable语句指定下列内容1.包含表的数据库2.表的所有者3.表名,在同一个数据库中和同一个所有者下,改表名必须与任何其他基表或视图不同4.指定1到1024个列5.主键约束(可选)6.1到250个Uniquer约束(可选)7.1到253个外键约束(可选)8.1个或者多个Check约束,限制插入表中的数据(可选)9.存储表的文件组(可选)/*创建表*/usedatabaseNameg

系统 2019-08-12 01:52:15 2558

SqlServer

SQLServer中char、varchar、nchar、nvarchar的

SQLSERVER中生成的语句中,字符串前加N。N前缀必须是大写字母。是Unicode编码的意思,一般来说,英文字符是一个字节组成,但是国际上的字太多了,因此就用两个字节来表示字符,满足国际化的需要.在字符串前面加上N代表存入数据库时以Unicode格式存储。N'string'表示string是个Unicode字符串Unicode字符串的格式与普通字符串相似,但它前面有一个N标识符(N代表SQL-92标准中的国际语言(NationalLanguage))。

系统 2019-08-12 01:54:39 2557

SqlServer

一个简单的游标删除SQL SERVER表

usedatabaseNamedeclare@tblnamechar(100)declare@sqlchar(5000)declaretable_cursorcursorforselectnamefromsysobjectswherenamelike'tb_card[_]%'andname<>'Tb_card_regist'andname<>'Tb_card_item'andname<>'Tb_card_discrule'andname<>'tb_card

系统 2019-08-12 01:52:52 2556