cpu95%,查找问题sql】的更多相关文章

收到一封告警邮件: Load average on xxx_server reached critical threshold values - 169.5 Current Load Avg = 169.5 是个生产环境的, 于是立马登上服务器看下状况 top - 05:01:00 up 88 days, 5:03, 4 users, load average: 185.10, 200.94, 193.27Tasks: 3442 total, 172 running, 3269 sleeping…
--查找bad sql的方法: select * from (select buffer_gets, sql_text from v$sqlarea ; -- 执行次数多的SQL select sql_text,executions from (select sql_text,executions from v$sqlarea order by executions desc) ; -- 读硬盘多的SQL select sql_text,disk_reads from (select sql_t…
sql的范围内查找 (1)between.....and用法 通常情况下我们查找一个在某固定区域内的所有记录,可以采用>=,<=来写sql语句,例如:查找订单价格在1000到2000之间的所有记录,可以这样写: 1 select * from sales.ordervalues 2 where val>=1000 and val<=2000 查询结果: 此处的sales.ordervalues来自于定义的视图,关于视图后续会讲到. 如果采用between.....and.....则…
def startTime=params.startTime+" 00:00:00"  def endTime=params.endTime + " 23:59:59"  def SQL ="from Timage where 1=1 "  params.max = 2 //设置偏移量  if (!params.offset) params.offset = 0  //  params.offset=""  if(params…
1.AppServiceProvider.php中 \DB::listen(function ($query){ $sql = $query->sql; $bindings = $query->bindings; $time = $query->time; if($time>10){ //when time > 10 print \Log::debug(var_export(compact(['sql','bindings','time']),true)); } }); 2.…
今天碰到个事.原本想把数据库设为单用户模式然后把REMOVE FILE.没想到悲剧了.因为很多进程都是需要远程连接这个库,导致别的进程抢在我前面连接了这个数据库,反到我连不上了.想把数据库切回MULTI_USER模式都做不了.老是报错说deadlock.这下我就急了.好在是开发环境.那解决办法就是找到那条占用了单用户进程的session然后kill掉它.调用下sp_who这个存储过程.然后马上切回MULTI_USER. if object_id('tempdb..#t') is not null…
接下来的文章是记录自己曾经的盲点,同时也透漏了自己的发展历程(可能发展也算不上,只能说是瞎混).当然,一些盲点也在工作和探究过程中慢慢有些眉目,现在也愿意发扬博客园的奉献精神,拿出来和大家分享一下. 开门见上,直接入题 在查看执行计划时候,你是否曾经也和我一样,有这样的疑惑呢?查找和扫描究竟是什么,以及他们的在查询性能上有什么区别.下面分享下我的理解. 扫描和查找是SQL Server从表或索引中读取数据所采用的迭代器,又因为经常在执行计划中看到,因此理解他们之间的区别,对我们优化查询有很重要的…
v$sqltext:存储的是完整的SQL,SQL被分割 v$sqlarea:存储的SQL 和一些相关的信息,比如累计的执行次数,逻辑读,物理读等统计信息(统计) v$sql:内存共享SQL区域中已经解析的SQL语句.(即时) 根据sid查找完整sql语句: select sql_text from v$sqltext a where a.hash_value = (select sql_hash_value from v$session b where b.sid = '&sid'    )or…
SQL Server分发服务器配置中,需要配置快照文件夹(Snapshot Folder),用于存储发布的数据和架构文件的工作目录,那么如何查找当前SQL Server数据库服务器的分发服务器的快照文件夹位置呢? 如果配置了具体发的发布和订阅,那么可以在对应的发布的属性->快照文件里面查看,如果还没有配置具体的发布和订阅,这个需要怎么查看呢? 今天恰巧遇到了这样的问题,研究了一下,其实这些值保存在表msdb.dbo.MSdistpublishers下面,如下所示. SELECT * FROM m…
在SQL Server中有几种方法可以找到活动的 SQL 连接.让我们看看一些使用 T-SQL 查询的简单快捷的方法. SP_WHO SP_WHO 是 SQL Server 内置的系统存储过程, 其他方法相比,SP_WHO 将具有最少的列,但是一种快速列出活动连接的方法. 以下是在 SQL Server Management Studio 中的执行示例: EXEC SP_WHO 具体的字段解释请参阅官方文档 SP_WHO 其中比较重要的列是: spid: 会话ID loginname: 登录账号…