MD5和SHA1是一种单向加密算法,常用于密码的验证等需要加密操作的场合,在一般情况下,开发人员可以通过Delphi或PHP这类语言自己编写相关函数或者使用自带的函数,然后将加密过的结果根据需要存储到数据库中。但在某些情况下,可能需要在数据库端计算MD5和SHA1哈希值,比如说在存储过程或自定义函数内部。开源数据库MySQL就提供类似这样的内置函数,以下语句就可以分别显示字符串“12345”的MD5和SHA1值,返回结果为字符串型:SELECTmd5('1
系统 2019-08-12 01:53:25 2432
一、深入浅出理解索引结构二、改善SQL语句三、实现小数据量和海量数据的通用分页显示存储过程聚集索引的重要性和如何选择聚集索引在上一节的标题中,笔者写的是:实现小数据量和海量数据的通用分页显示存储过程。这是因为在将本存储过程应用于“办公自动化”系统的实践中时,笔者发现这第三种存储过程在小数据量的情况下,有如下现象:1、分页速度一般维持在1秒和3秒之间。2、在查询最后一页时,速度一般为5秒至8秒,哪怕分页总数只有3页或30万页。虽然在超大容量情况下,这个分页的
系统 2019-08-12 01:32:53 2432
SQLServer时间日期函数详解,SQLServer,时间日期,1.当前系统日期、时间selectgetdate()2.dateadd在向指定日期加上一段时间的基础上,返回新的datetime值例如:向日期加上2天selectdateadd(day,2,'2004-10-15')--返回:2004-10-1700:00:00.0003.datediff返回跨两个指定日期的日期和时间边界数。selectdatediff(day,'2004-09-01','
系统 2019-08-12 01:54:39 2430
TRY...CATCH是SqlServer2005/2008令人印象深刻的新特性.提高了开发人员异常处理能力.没有理由不尝试一下Try..Catch功能.*TRY块-包含可能产生异常的代码或脚本*CATCH块-如果TRY块出现异常,代码处理流将被路由到CATCH块.在这里你可以处理异常,记录日志等.SqlServer中的TryCatch和C#,JAVA等语言的处理方式一脉相承.这种一致性才是最大的创新之处.SQLSERVER2000中异常处理:CREATE
系统 2019-08-12 01:52:30 2430
以前拼接的写法set@sql='select*fromtablewhere1=1'if(@addDateisnotnull)set@sql=@sql+'andaddDate='+@addDate+''if(@name<>''andisnotnull)set@sql=@sql+'andname='+@name+''exec(@sql)下面是不采用拼接SQL字符串实现多条件查询的解决方案第一种写法是感觉代码有些冗余if(@addDateisnotnull)an
系统 2019-08-12 01:33:49 2430
在低版本的PowerDesigner中,很多人会使用以下脚本生成SQLServer的表注释和列注释信息:----表级的注释代码是:EXECUTEsp_addextendedpropertyNMS_Description,N%COMMENT%,Nuser,N%OWNER%,Ntable,N%TABLE%,NULL,NULL----列级的注释代码是EXECUTEsp_addextendedpropertyNMS_Description,N%COMMENT%,N
系统 2019-08-29 23:09:52 2428
用openrowset连接远程SQL或插入数据--如果只是临时访问,可以直接用openrowset--查询示例select*fromopenrowset('SQLOLEDB','sql服务器名';'用户名';'密码',数据库名.dbo.表名)--导入示例select*into表fromopenrowset('SQLOLEDB','sql服务器名';'用户名';'密码',数据库名.dbo.表名)--创建链接服务器execsp_addlinkedserver'
系统 2019-08-12 01:55:16 2428
一、数据插入1、语法INSERTINTO表名[<属性列>]VALUES(参数列表)注解:①没有说明属性列,即要给出所有的列的值②不确定的列,可以设置为null。(在允许为空的情况下)2、实例①在“人事管理系统”中,新增一个员工信息(员工编号‘100508’、员工姓名‘小龙女’、所在部门编号‘10001’、籍贯‘河南’)insertinto员工信息(员工编号,员工姓名,所在部门编号,籍贯)values('100508','小龙女','10001','河南')
系统 2019-08-12 01:53:44 2428
我们在在使用SQLServer时都会遇到使用SQLServerManagementStudio无法连接远程数据库实例的问题,错误描述信息摘录如下:Anerrorhasoccurredwhileestablishingaconnectiontotheserver.(provider:NamedPipesProvider,error:40–CouldnotopenaconnectiontoSQLServer)(MicrosoftSQLServer,Error:
系统 2019-08-12 01:53:32 2428
在SQLServer中,我常常会看到有些前辈这样写:if(@@error<>0)ROLLBACKTRANSACTIONTelseCOMMITTRANSACTIONT一开始,我看见别人这么写,我就想当然的以为它只是个计数器,每当检测到一处错误时,@@error的值+1,不过就因为这个理所当然,所以杯具了...实际上,它并不是一个计数器,它是一个动态的值,动态的标识最后一条SQL命令执行的结果,如果成功则为0,不成功则标识错误码。所以,像上面这种写法是不妥的,
系统 2019-08-12 01:51:54 2428
SQLServer的通用分页显示存储过程2005-12-0214:50freedk我要评论(5)字号:T|T本文详述实现小数据量和海量数据的通用分页显示存储过程AD:2013大数据全球技术峰会低价抢票中建立一个Web应用,分页浏览功能必不可少。这个问题是数据库处理中十分常见的问题。经典的数据分页方法是:ADO纪录集分页法,也就是利用ADO自带的分页功能(利用游标)来实现分页。但这种分页方法仅适用于较小数据量的情形,因为游标本身有缺点:游标是存放在内存中,很
系统 2019-08-12 01:51:27 2428
--按姓氏笔画排序:SELECT*FROMTableNameORDERBYCustomerNameCOLLATEChinese_PRC_Stroke_ci_as--数据库加密:SELECTencrypt('原始密码')SELECTpwdencrypt('原始密码')SELECTpwdcompare('原始密码','加密后密码')=1--相同;否则不相同encrypt('原始密码')SELECTpwdencrypt('原始密码')SELECTpwdcompa
系统 2019-08-12 01:52:14 2427
SQLServer2008中SQL应用系列--目录索引证书和非对称密钥使用数据库级的内部公钥加密数据,并且使用数据库级内部私钥解密数据。而对称密钥相对简单,它们包含一个同时用来加密和解密的密钥。困此,使用对称密钥加密数据更快,并且用在大数据时更加合适。尽管复杂度是考虑使用它的因素,但它仍然是一个很好的加密数据的选择。我们看一组例子:示例一、创建对称密钥对称密钥的特性是:在数据库会话中使用它对数据进行加密和解密前必须首先打开。创建对称密钥使用如下命令:CRE
系统 2019-08-29 23:18:38 2426
9月份收到了Microsoft寄来的《MicrosoftSQLServer2005:数据库基础由入门到精通》,翻着看了一遍然后又精读了其中的一些章节之后,我决定开始为它写书评。我们都知道,学习使用SQL语言并不难,无非就是SELECT、INSERT、UPDATE、DELETE这四大指令,外加一些各种功能的子句,人人都能轻松学会编写一些简单的SQL语句。然而这与真正懂得使用一套SQLServer这样的数据库管理系统有多远?大概也就是一亿五千万个字节的距离。何
系统 2019-08-12 01:55:35 2426
查了好多资料,发现还是不全,干脆自己整理吧,至少保证在我的做法正确的,以免误导读者,也是给自己做个记载吧!一、数据库提要1、系统数据库(1)master①述描:记载全部SQLServer系统级信息。(2)model①述描:这是一个模板数据库。当建创户用数据库时,系统动自把该数据库的全部信息复制到户用新建的数据中。(3)msdb①述描:这是与SQLServerAgent服务有关的数据库。(4)tempdb①述描:这个一个临时数据库。2、数据库文件提要(1)数
系统 2019-08-12 01:52:43 2426