-
SqlServer巧妙解决多条件组合查询
开发中经常会遇得到需要多种条件组合查询的情况,比如有三个表,年级表Grade(GradeId,GradeName),班级Class(ClassId,ClassName,GradeId),学员表Student(StuId,StuName,ClassId),现要求可以按年级Id、班级Id、学生名,这三个条件可以任意组合查询学员信息。 做法不止一种,这里提供一种巧妙的使用一条查询来实现的办法,我们来写成一个过程,如下:复制代码代码如下:createprocup_select_student_combocondition@gradeIdint,@classIdint,@stuNamenvarchar(10)asselects.*,c.classname,g.gradenamefromstudentsjoinclasscons.classid=c.classidjoingradegonc.gradeid=g.gradeidwhere(@gradeId=-1org.gradeid=@gradeId)and(@classId=-1orc.classid=@classId)and(@stuName='...
数据库操作教程 2022-09-23 16:49:59 -
SQLserver高级应用收藏版
一.建库,建表,加约束.1.1建库复制代码代码如下:usemastergoifexists(select*fromsysdatabaseswherename='MyDatabase')—判断master数据库sysdatagbases表中是否存在将要创建的数据库名dropdatabaseMyDatabase—如果sysdatabases表中存在该数据库名,则将它删除goexecxp_cmdshell‘mdD:/MyDatabases'—利用存储过程创建一个文件夹用于存储数据物理文件(数据文件,日志文件),DOS命令(mkdir=md)gocreatedatabaseMyDatabase—创建数据库on(name='MyDatabase_data',--指定逻辑文件名filename='D:/MyDatabases/MyDatabase_data.mdf',--指定物理文件名size=5mb,--初始大小maxsize=50mb,--指定物理文件最大容量,可选filegrowth=20%--增长量)logon(name='MyDatabase_log',--指定逻辑日志文件名filena...
数据库操作教程 2022-09-23 16:49:46 -
T-SQL篇如何防止SQL注入的解决方法
1.什么是SQL注入所谓SQL注入式攻击,就是攻击者把SQL命令插入到Web表单的输入域或页面请求的查询字符串,欺骗服务器执行恶意的SQL命令。在某些表单中,用户输入的内容直接用来构造(或者影响)动态SQL命令,或作为存储过程的输入参数,这类表单特别容易受到SQL注入式攻击...
数据库操作教程 2022-09-23 16:49:21 -
sql无效字符执行sql语句报错解决方案
说起来惭愧,总是犯一些小错误,纠结半天,这不应为一个分号的玩意折腾了好半天!错误时在执行SQL语句的时候发出的,信息如下:Java代码[default][2012-11-2211:35:58,552][ERROR]Java代码[com.primeton.common.connection.impl.synchronization.TraceLoggerStatementSynchronization:49]Java代码Sql[INSERTINTOASE_SYSTEM_LOG(LOGID,USERID,USERNAME,LOGINTIME)VALUES(?,?,?,?);]executeerror.java.sql.SQLException:ORA-00911:无效字符程序代码如下:Java代码复制代码代码如下:Stringsql="INSERTINTOASE_SYSTEM_LOG(LOGID,USERID,USERNAME,LOGINTIME)VALUES(?,?,?,?);";con=this.getDataSource().getConnection();ptt=con.prepa...
数据库操作教程 2022-09-23 16:48:52 -
SQLSERVER如何判断某个字段包含大写字母
sql语句中默认是不区分大小写的,所以语句:Sql代码SELECT*FROMRecEngineBizInfoWHERERecEngineBizName='QQ'和Sql代码SELECT*FROMRecEngineBizInfoWHERERecEngineBizName='qq'查到的结果是一样的。要查看某个字段是否包含大写字母A的脚本为:Sql代码select*fromRecEngineBizInfowhereRecEngineBizNamecollateChinese_PRC_CS_AS_WSlike'%A%'www.jb51.net要查看某个字段是否包含大写字母的脚本为:Sql代码SELECT*FROMRecEngineBizInforebiWHERErebi.RecEngineBizNameCOLLATEChinese_PRC_CS_ASlike'%[ABCDEFGHIJKLMNOPQRSTUVWXYZ]%'要查看某个字段是否包含连续两个大写字母的脚本为:Sql代码SELECT*FROMRecEngineAttributeInforeaiWHEREreai.ZhiLingCOLL...
数据库操作教程 2022-09-23 16:48:02 -
安装sqlserver2000时出现wowexec.exe无反应的解决方法
wowexec.exe是操作系统相关程序,用于支持16位进程。 出品者:MicrosoftCorp. 属于:MicrosoftWindowsOnWindowsExecutionProcess 系统进程:是 后台程序:否 使用网络:否 硬件相关:否 常见错误:未知N/A 内存使用:未知N/A 安全等级(0-5):0 间谍软件:否 Adware:否 病毒:否 木马:否 ※解释: 一直以来大家认为这是WINDOWS的自动更新程序,只要关闭自动更新就不会再出现...
数据库操作教程 2022-09-23 16:47:18 -
如何恢复数据库的账号登录名/用户名等
当我们重装系统,或者是重装数据库之后,当附加数据库之后,发现数据库里面有用户名,但是在sqlserver里面没有登陆名例如先看 用户名 是有他上次系统的用户名的现在我们先去添加这个登录名点击取消进入查询分析器,选择你要修复的数据库sp_change_users_login'report' 这个可以查询当前数据库下的孤立用户 我们只需要选择当前数据库为你要修复的数据库,然后运行sp_change_users_login'update_one','用户名','登录名' 系统就会提示修复了一个孤立用户。重新刷新数据库的用户,会看到用户名和登录名对应了...
数据库操作教程 2022-09-23 16:47:05 -
如何优化SQL语句的心得浅谈
(1)选择最有效率的表名顺序(只在基于规则的优化器中有效):Oracle的解析器按照从右到左的顺序处理FROM子句中的表名,FROM子句中写在最后的表(基础表drivingtable)将被最先处理,在FROM子句中包含多个表的情况下,你必须选择记录条数最少的表作为基础表。如果有3个以上的表连接查询,那就需要选择交叉表(intersectiontable)作为基础表,交叉表是指那个被其他表所引用的表...
数据库操作教程 2022-09-23 16:46:50 -
附加到SQL2012的数据库就不能再附加到低于SQL2012的数据库版本的解决方法
昨天我只是将数据库附加到SQL2012,然后各个数据库都做了收缩事务日志的操作兼容级别这些都没有改再附加回SQL2005的时候就报错在SQL2012里附加,确实是90级别,但是在SQL2005死活附加不上备份数据库再还原也是一样重建事务日志也是一样然后我做了一个实验,检查一下附加到SQL2012的数据库和附加到SQL2005的数据库,两个数据库的文件头有什么不同注意:两个数据库的兼容级别都是90,附加到SQL2012之后我也没有动过兼容级别!!我们用同一个数据库,分别附加到SQL2005上和SQL2012上,看一下附加之后数据库的文件头有没有改变这个数据库的兼容级别是90的附加到SQL2012之后,我也不改变他的兼容级别查看文件头的SQL语句如下,实际上就是数据库的第0页:复制代码代码如下:DBCCTRACEON(3604,-1)DBCCPAGE(dlgpos,1,0,3)在SQL2012里和SQL2005里都执行一下将结果复制粘贴到一个新建的记事本里,命名好复制代码代码如下:DBCC执行完毕。如果DBCC输出了错误信息,请与系统管理员联系...
数据库操作教程 2022-09-23 16:46:24 -
SQL实现递归及存储过程中In()参数传递解决方案详解
1.SQL递归在SQLServer中,我们可以利用表表达式来实现递归算法,一般用于阻止机构的加载及相关性处理。-->实现:假设OrganiseUnit(组织机构表)中主要的三个字段为OrganiseUnitID(组织机构主键ID)、ParentOrganiseUnitID(组织机构父ID)、OrganiseName(组织机构名称)复制代码代码如下:withorganiseas(select*fromOrganiseUnitwhereOrganiseUnit.OrganiseUnitID=@OrganiseUnitIDunionallselectOrganiseUnit.*fromorganise,OrganiseUnitwhereorganise.OrganiseUnitID=OrganiseUnit.ParentOrganiseUnitID)selectOrganiseNamefromorganise上述sql语句实现了,传入组织机构主键ID,查询出其对应组织机构名称和其全部下级组织机构名称...
数据库操作教程 2022-09-23 16:46:20 -
win2008r2安装sqlserver2005/2008无法连接服务器解决方法
在与SQLServer建立连接时出现与网络相关的或特定于实例的错误。未找到或无法访问服务器...
数据库操作教程 2022-09-23 16:45:39 -
SQLServer2012中设置AlwaysOn解决网络抖动导致的提交延迟问题
事件起因:近期有研发反应,某数据库从08切换到12环境后,不定期出现写操作提交延迟的问题;事件分析:在排除了系统资源争用等问题后,初步分析可能由于网络抖动导致同步模式alwayson节点经常出现会话超时等待提交的问题导致。经过排查,扩展事件里发现不定期出现35202错误,这是一条副本连接恢复的消息...
数据库操作教程 2022-09-23 16:45:22