1、首先我们打开电脑里的sql server软件。
2、打开电脑的开始菜单,选择“控制面板”选项。
3、在“控制面板”选项卡中,选择“管理工具”选项。
4、在“管理工具”选项卡中,选择“服务”界面。
5、在“服务”中,找到sql 开头的服务名。
6、这个“SQL Server (MSSQLSERVER)”服务后缀就"MSSQLSERVER"是该数据库的实例名。
oracle 10g的DBMS_XPLAN包中display_cursor函数不同于display函数,display_cursor用于显示SQL语句的真实的执行计划,在大多数情况下,
显示真实的执行计划有助于更好的分析SQL语句的全过程,尤其是运行此SQL语句实时的I/O开销。通过对比预估的I/O与真实的I/O开销来判断
SQL语句所存在问题,如缺少统计信息,SQL语句执行的次数,根据实际中间结果集的大小来选择合适的连接方式等。本文仅仅讲述
display_cursor函数的使用。
一、display_cursor函数用法
1、display_cursor函数语法
DBMS_XPLANDISPLAY_CURSOR(
sql_id IN VARCHAR2 DEFAULT NULL,
cursor_child_no IN NUMBER DEFAULT NULL,
format IN VARCHAR2 DEFAULT 'TYPICAL');
2、display_cursor函数参数描述
sql_id
指定位于库缓存执行计划中SQL语句的父游标。默认值为null。当使用默认值时当前会话的最后一条SQL语句的执行计划将被返回
可以通过查询V$SQL 或V$SQLAREA的SQL_ID列来获得SQL语句的SQL_ID。
cursor_child_no
指定父游标下子游标的序号。即指定被返回执行计划的SQL语句的子游标。默认值为0。如果为null,则sql_id所指父游标下所有子游标
的执行计划都将被返回。
format
控制SQL语句执行计划的输出部分,即哪些可以显示哪些不显示。使用与display函数的format参数与修饰符在这里同样适用。
除此之外当在开启statistics_level=all时或使用gather_plan_statistics提示可以获得执行计划中实时的统计信息
有关详细的format格式描述请参考:dbms_xplan之display函数的使用 中format参数的描述
下面给出启用统计信息时format新增的修饰符
iostats 控制I/O统计的显示
last 默认,显示所有执行计算过的统计。如果指定该值,则只显示最后一次执行的统计信息
memstats 控制pga相关统计的显示
allstats 此为iostats memstats的快捷方式,即allstats包含了iostats和memstats
run_stats_last 等同于iostats last。只能用于oracle 10g R1
run_stats_tot 等同于iostats。只能用于oracle 10g R1
抓一个最近一小时最消耗IO的SQL:
SELECT sql_id, COUNT()
FROM gv$active_session_history ash, gv$event_name evt
WHERE ashsample_time > SYSDATE - 1 / 24
AND ashsession_state = 'WAITING'
AND ashevent_id = evtevent_id
AND evtwait_class = 'User I/O'
GROUP BY sql_id
ORDER BY COUNT() DESC;
执行上面的SQL:
SQL> SELECT sql_id, COUNT()
FROM gv$active_session_history ash, gv$event_name evt
2 3 WHERE ashsample_time > SYSDATE - 1 / 24
4 AND ashsession_state = 'WAITING'
5 AND ashevent_id = evtevent_id
6 AND evtwait_class = 'User I/O'
7 GROUP BY sql_id
8 ORDER BY COUNT() DESC;
SQL_ID COUNT()
------------- ----------
g7fu6qba82m6b 668
63r47zyphdk06 526
9f5m4wd88nc1h 514
593p47drw5fhk 232
br91w16jzy4fu 120
4fvwyjpnh6tp7 78
gm0nrbfuj8kzr 70
2184k363hw4xd 68
gc4dajs7g5myy 46
8vrk9sfuwfdgq 42
ccpnb4dwdmq21 40
查看SQL的执行计划:
SELECT FROM TABLE(dbms_xplandisplay_cursor('g7fu6qba82m6b'));
在SQLPLUS中执行:
SQL> set pagesize 2000
SQL> SELECT FROM TABLE(dbms_xplandisplay_cursor('g7fu6qba82m6b'));
PLAN_TABLE_OUTPUT
------------------------------------------------------------------------------------------------------------------------
SQL_ID g7fu6qba82m6b, child number 0
-------------------------------------
UPDATE "CPDDS_PDATA""CDM_LEDGER" SET "CSTM_NAME" = :a1,"CSTM_NO" =
:a2,"PAPER_TYPE" = :a3,"PAPER_NO" = :a4,"CURR_TYPE" = :a5,"SVT_NO" =
:a6,"BAL_DIR" = :a7,"BAL" = :a8,"AVAL_BAL" = :a9,"NORM_FRATIO" =
:a10,"PK_BAL" = :a11,"DR_ACCU" = :a12,"CR_ACCU" = :a13,"LAST_TRAN_DATE" =
:a14,"LAST_TRAN_TIME" = :a15,"PRT_LINE_NUM" = :a16,"NOREG_PK_REC_NUM" =
:a17,"PK_NO" = :a18,"PWD" = :a19,"FLAG" = :a20,"FRZ_FLAG" =
:a21,"CARD_HOLD_FLAG" = :a22,"PK_HOLD_FLAG" = :a23,"BGN_INT_DATE" =
:a24,"OPEN_DATE" = :a25,"ACC_HOLD_FLAG" = :a26,"CLS_DATE" =
:a27,"OPEN_TLR" = :a28,"CLS_TLR" = :a29,"CLS_INT" = :a30,"OPEN_INST" =
:a31,"ADD_NUM" = :a32,"DAC" = :a33,"FRZ_TIMES1" = :a34,"FRZ_TIMES2" =
:a35,"HOST_SEQNO" = :a36,"D_UPDATE_DATE" = :a37 WHERE "ACC" = :b0
Plan hash value: 319441092
-----------------------------------------------------------------------------------
| Id | Operation | Name | Rows | Bytes | Cost (%CPU)| Time |
-----------------------------------------------------------------------------------
| 0 | UPDATE STATEMENT | | | | 3 (100)| |
| 1 | UPDATE | CDM_LEDGER | | | | |
| 2 | INDEX UNIQUE SCAN| I_CDM_LEDGER | 1 | 269 | 2 (0)| 00:00:01 |
-----------------------------------------------------------------------------------
Predicate Information (identified by operation id):
---------------------------------------------------
2 - access("ACC"=:B0)
29 rows selected
总结
1、与display函数不同,display_cursor显示的为真实的执行计划
2、对于format参数,使用与display函数的各个值,同样适用于display_cursor函数
3、当statistics_level为all或使用gather_plan_statistics提示可以获得执行时的统计信息
4、根据真实与预估的统计信息可以初步判断SQL效率低下的原因,如统计信息的准确性、主要的开销位于那些步骤等
sql语句:select from dba_dependencies where REFERENCED='表名' and TYPE='VIEW'; 静态数据字典视图DBA_DEPENDENCIES描述各schema的objects之间的相互依赖关系。
目测语法是 Oracle 数据库的语法。
那么, 如果这个where aptitudecompanyid=com_baseid;条件获得上面执行的com_baseid怎么获取啊?
可以通过 :oldid 或者 :newid 来获取。
例如:
SQL> CREATE OR REPLACE TRIGGER BeforeUpdateTest
2 BEFORE UPDATE ON test_trigger_table
3 FOR EACH ROW
4 BEGIN
5 dbms_outputput_line('BEFORE UPDATE');
6 dbms_outputput_line('Old Name = ' || :oldname);
7 dbms_outputput_line('New Name = ' || :newname);
8 END;
9 /
Trigger created
SQL>
SQL> UPDATE test_trigger_table SET name = 'XYZ' WHERE id = 1;
BEFORE UPDATE
Old Name = ABC
New Name = XYZ
第一步建连接:就是一java连接就行
第二步是建立一个类这类的与数据库字段对象用于java的面向对象importjavautilDate;
//存放数据的javabean,属性和表中的字段是一一对应的publicclassUser{
privateintuserid;
privateStringusername;
privateStringpassword;
privateDatelogintime;
publicUser(){
}
publicvoidsetUserid(intuserid){
thisuserid=userid;
}
publicvoidsetUsername(Stringusername){
thisusername=username;
}
publicvoidsetPassword(Stringpassword){
thispassword=password;
}
publicvoid(Datelogintime){
thislogintime=logintime;
}
publicintgetUserid(){
returnuserid;
}
publicStringgetUsername(){
returnusername;
}
publicStringgetPassword(){
returnpassword;
}
publicDate(){
returnlogintime;
}}
第三步是建立一个SQL访问类:importjavasql;importjavautil;publicclassUserDAO{
//按条件查找多条记录
publicListfindAll(Stringfilter){
Connectionconn=Db();
Listdatas=newArrayList();
if(filter!=null){
filter="where"filter;
}else{
filter="";
}
try{
ps=conn(
"selectfromusertb"filter);
ResultSetrs=ps();
while(rsnext()){
Useruser=newUser();
usersetUserid(rsgetInt(1));
usersetUsername(rsgetString(2));
usersetPassword(rsgetString(3));
user(rsgetDate(4));
datasadd(user);
}
}catch(ex){
ex();
}finally{
DbcloseConn(conn);
}
returndatas;
}}第四步是这在jsp上用来访问SQL访问类调用方法获取数据
实现的方法和详细的 *** 作步骤如下:
1、第一步,打开SQL
Server软件,然后选择图中“数据库”选项前面的“ +”号以展开数据库,如下图所示,然后进入下一步。
2、其次,完成上述步骤后,使用相同的方法选择图中红色框中标记的数据库,该数据库是用户添加的数据库,如下图所示,然后进入下一步。
3、接着,完成上述步骤后,选择红色框中的“表”选项以将其展开,如下图所示,然后进入下一步。
4、然后,完成上述步骤后,红色框是数据库中表的名称,请记住这些名称,然后才有用,如下图所示,然后进入下一步。
5、随后,完成上述步骤后,再次选择添加的数据库,将其选中,然后单击“新建查询”按钮,如下图所示,然后进入下一步。
6、接着,完成上述步骤后,在软件的右侧,将显示新页面,见下图,然后进入下一步。
7、然后,完成上述步骤后,输入符合SQL语法的SQL语句,然后点击图中标记的“执行”按钮以执行SQL语句,如下图所示,然后进入下一步。
8、最后,完成上述步骤后,就获得了想要的结果了,如下图所示。这样,问题就解决了。
以上就是关于sql server 如何获取当前 *** 作的数据库名全部的内容,包括:sql server 如何获取当前 *** 作的数据库名、怎么获取PreparedStatement 的最终执行SQL、怎么在Oracle 中获取某个应用执行的sql语句等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)