实战派 好教育     全国咨询热线:400-009-1906

北京 切换校区

全国24小时免费热线

400-009-1906

40个DBA日常维护的SQL脚本

时间:2018-05-18   来源:   阅读:209
首页> 40个DBA日常维护的SQL脚本

  1、查询碎片程度高的表

  条件为什么block>100,因为一些很小的表,只有几行数据实际大小很小,但是block一次性分配就是5个(11g开始默认一次性分配1M的block大小了,见createtablestorged的NEXT参数),5个block相对于几行小表数据来说就相差太大了。
  算法中/0.9是因为块的pfree一般为10%,所以一个块最多只用了90%,而且一行数据大于8KB时容易产生行链接,把一行分片存储,一样的一个块连90%都用不满。
  AVG_ROW_LEN还是比较准的,比如个人实验情况一表6个字段,一个number,其他5个都是char(100)但是实际数据都是’1111111’7位,AVG_ROW_LEN显示依然为513
  SELECTTABLE_NAME,(BLOCKS*8192/1024/1024)"理论大小M",
  (NUM_ROWS*AVG_ROW_LEN/1024/1024/0.9)"实际大小M",
  round((NUM_ROWS*AVG_ROW_LEN/1024/1024/0.9)/(BLOCKS*8192/1024/1024),3)*100||'%'"实际使用率%"
  FROMUSER_TABLESwhereblocks>100and(NUM_ROWS*AVG_ROW_LEN/1024/1024/0.9)/(BLOCKS*8192/1024/1024)<0.3
  orderby(NUM_ROWS*AVG_ROW_LEN/1024/1024/0.9)/(BLOCKS*8192/1024/1024)desc
  2、查询索引碎片的比例
  selectname,del_lf_rows,lf_rows,round(del_lf_rows/decode(lf_rows,0,1,lf_rows)*100,0)||'%'frag_pctfromindex_statswhereround(del_lf_rows/decode(lf_rows,0,1,lf_rows)*100,0)>30;
  3、集群因子clustering_factor高的表
  集群因子越接近块数越好,接近行数则说明索引列的列值相等的行分布极度散列,可能不走索引扫描而走全表扫描
  selecttab.table_name,tab.blocks,tab.num_rows,ind.index_name,ind.clustering_factor,
  round(nvl(ind.clustering_factor,1)/decode(tab.num_rows,0,1,tab.num_rows),3)*100||'%'"集群因子接近行数"
  fromuser_tablestab,user_indexesindwheretab.table_name=ind.table_name
  andtab.blocks>100
  andnvl(ind.clustering_factor,1)/decode(tab.num_rows,0,1,tab.num_rows)between0.35and3
  4、根据sid查spid或根据spid查sid
  selects.sid,s.serial#,s.LOGON_TIME,s.machine,p.spid,p.terminalfromv$sessions,v$processpwheres.paddr=p.addrands.sid=XXorp.spid=YY
  5、根据sid查看具体的SQL语句
  selectusername,sql_text,machine,osuserfromv$sessiona,v$sqltext_with_newlinesb
  whereDECODE(a.sql_hash_value,0,prev_hash_value,sql_hash_value)=b.hash_valueanda.sid=&sidorderbypiece;
  6、根据spid查询具体的sql语句
  selectss.SID,pr.SPID,ss.action,sa.SQL_FULLTEXT,ss.TERMINAL,ss.PROGRAM,ss.SERIAL#,ss.USERNAME,ss.STATUS,ss.OSUSER,ss.last_call_et
  fromv$processpr,v$sessionss,v$sqlareasa
  wheress.status='ACTIVE'andss.usernameisnotnullandpr.ADDR=ss.PADDR
  andss.SQL_ADDRESS=sa.ADDRESSandss.SQL_HASH_VALUE=sa.HASH_VALUE
  andpr.spid=XX
  7、查看历史session_id的SQL来自哪个IP
  (当然这是个误解,都是历史的了,怎么可能还查到spid,其实查看trace文件名就可以知道spid,trace文件里面有sid和具体sql,如果trace存在incident,那trace就看不到具体sql,但是可以在incident文件中看到具体的sql,如DW_ora_17751.trc中17751就是spid,里面有这样的内容Incident115created,dumpfile:/XX/incident/incdir_115/DW_ora_17751_i115.trc,那么在DW_ora_17751_i115.trc就可以看到具体的sql语句)
  DB_ora_29349.trc中出现如下
  ***SESSIONID:(5057.12807)2016-10-2614:45:52.726
  通过表V$ACTIVE_SESSION_HISTORY来查,如下
  selecta.sql_id,a.machine,a.*fromV$ACTIVE_SESSION_HISTORYawherea.session_id=5057anda.SESSION_SERIAL#=12807
  查询上面的machine的IP是多少
  selects.sid,s.serial#,s.LOGON_TIME,s.machine,p.spid,p.terminalfromv$sessions,v$processpwheres.paddr=p.addrands.machine='localhost'
  通过上面的spid在oracle服务器上执行netstat-anp|grepspid即可
  [oracle@dwdbtrace]$netstat-anp|grep17630
  tcp2100192.168.64.228:11095192.168.21.16:1521ESTABLISHED17630/oracleDB
  tcp00::ffff:192.168.64.228:1521::ffff:192.168.64.220:59848ESTABLISHED17630/oracleDB
  出现两个,说明来自220,连接了228数据库服务器,但是又通过228服务器的dblink去连接了16服务器
  8、查询DML死锁会话sid,及引起死锁的堵塞者会话blocking_session
  selectsid,blocking_session,LOGON_TIME,sql_id,status,event,seconds_in_wait,state,BLOCKING_SESSION_STATUSfromv$sessionwhereeventlike'enq%'andstate='WAITING'andBLOCKING_SESSION_STATUS='VALID'
  BLOCKING_SESSION:Sessionidentifieroftheblockingsession.ThiscolumnisvalidonlyifBLOCKING_SESSION_STATUShasthevalueVALID.
  可以在v$session.LOGON_TIME上看到引起死锁的堵塞者会话比等待者要早
  如果遇到RAC环境,一定要用gv$来查,并且执行altersystemkillsession'sid,serial#'要到RAC对应的实例上去执行
  或如下也可以
  select
  (selectusernamefromv$sessionwheresid=a.sid)blocker,
  a.sid,
  a.id1,
  a.id2,
  'isblocking'"ISBLOCKING",
  (selectusernamefromv$sessionwheresid=b.sid)blockee,
  b.sid
  fromv$locka,v$lockb
  wherea.block=1
  andb.request>0
  anda.id1=b.id1
  anda.id2=b.id2;
  9、查询DDL锁的sql
  SELECTsid,event,p1raw,seconds_in_wait,wait_time
  FROMsys.v_$session_wait
  WHEREeventlike'librarycache%'
  p1raw结果为'0000000453992440'
  SELECTs.sid,kglpnmod"Mode",kglpnreq"Req",s.LOGON_TIME
  FROMx$kglpnp,v$sessions
  WHEREp.kglpnuse=s.saddr
  ANDkglpnhdl='0000000453992440';
  结果为671032011-11-112:00:00
  525202011-11-412:00:00
  10、查询锁住的DDL对象
  selectd.session_id,s.SERIAL#,d.namefromdba_ddl_locksd,v$sessionswhered.owner='MKLMIGEM'andd.SESSION_ID=s.sid
  11、查询当前正在执行的sql
  SELECTs.sid,s.serial#,s.username,spid,v$sql.sql_id,machine,s.terminal,s.program,sql_text
  FROMv$process,v$sessions,v$sql
  WHEREaddr=paddrands.sql_id=v$sql.sql_idANDsql_hash_value=hash_value
  12、查询正在执行的SCHEDULER_JOB
  selectowner,job_name,sid,b.SERIAL#,b.username,spidfromALL_SCHEDULER_RUNNING_JOBS,v$sessionb,v$processwheresession_id=sidandpaddr=addr
  13、查询正在执行的dbms_job
  selectjob,b.sid,b.SERIAL#,b.username,spidfromDBA_JOBS_RUNNINGa,v$sessionb,v$processwherea.sid=b.sidandpaddr=addr
  14、查询一个会话session、process平均消耗多少内存,查看下面avg_used_M值
  selectround(sum(pga_used_mem)/1024/1024,0)total_used_M,round(sum(pga_used_mem)/count(1)/1024/1024,0)avg_used_M,
  round(sum(pga_alloc_mem)/1024/1024,0)total_alloc_M,round(sum(pga_alloc_mem)/count(1)/1024/1024,0)avg_alloc_Mfromv$process;
  15、TOP10执行次数排序
  select*
  from(selectexecutions,username,PARSING_USER_ID,sql_id,sql_text
  fromv$sql,dba_userswhereuser_id=PARSING_USER_IDorderbyexecutionsdesc)
  whererownum<=5;
  16、TOP10物理读排序
  select*
  from(selectDISK_READS,username,PARSING_USER_ID,sql_id,ELAPSED_TIME/1000000,sql_text
  fromv$sql,dba_userswhereuser_id=PARSING_USER_IDorderbyDISK_READSdesc)
  whererownum<=5;
  (不要使用DISK_READS/EXECUTIONS来排序,因为任何一条语句不管执行几次都会耗逻辑读和cpu,可能不会耗物理读(遇到LRU还会耗物理读,LRU规则是执行最不频繁的且最后一次执行时间距离现在最久远的就会被交互出buffercache),是因为buffercache存放的是数据块,去数据块里找行一定会消耗cpu和逻辑读的。Sharedpool执行存放sql的解析结果,sql执行的时候只是去sharepool中找hashvalue,如果有匹配的就是软解析。所以物理读逻辑读是在buffercache中,软解析硬解析是在sharedpool)
  17、TOP10逻辑读排序
  select*
  from(selectBUFFER_GETS,username,PARSING_USER_ID,sql_id,ELAPSED_TIME/1000000,sql_text
  fromv$sql,dba_userswhereuser_id=PARSING_USER_IDorderbyBUFFER_GETSdesc)
  whererownum<=5;
  (不要使用BUFFER_GETS/EXECUTIONS来排序,原因同16)
  18、TOP10CPU排序
  select*
  from(selectCPU_TIME/1000000,username,PARSING_USER_ID,sql_id,ELAPSED_TIME/1000000,sql_text
  fromv$sql,dba_userswhereuser_id=PARSING_USER_IDorderbyCPU_TIME/1000000desc)
  whererownum<=5;
  (不要使用CPU_TIME/EXECUTIONS来排序,原因同16)
  19、查询等待事件
  selectevent,sum(decode(wait_time,0,0,1))"之前等待次数",sum(decode(wait_time,0,1,0))"正在等待次数",count(*)fromv$session_waitgroupbyeventorderby4desc
  20、查询当前正在消耗temp空间的sql语句
  Selectdistinctse.username,
  se.sid,
  su.blocks*to_number(rtrim(p.value))/1024/1024asspace_G,
  su.tablespace,
  sql_text
  fromV$TEMPSEG_USAGEsu,v$parameterp,v$sessionse,v$sqls
  wherep.name='db_block_size'
  andsu.session_addr=se.saddr
  andsu.sqlhash=s.hash_value
  andsu.sqladdr=s.address
  21、查询需要使用绑定变量的sql,10G以后推荐第二种
  (任何一条执行过的语句不管执行了几次在V$SQL中都只有一条记录,V$SQL中会记录执行了几次。两条一模一样的语句但是在不同的schema下执行的两种结果,如select*fromt1.test在sye、system下执行则V$SQL只有一条记录(谁先执行则PARSING_SCHEMA_NAME显示谁)。如在sys和system都执行select*fromtest则V$SQL中有两条记录,两条记录的CHILD_NUMBER和PARSING_SCHEMA_NAME不一样。同一个用户下执行一样的语句如果大小写不一样或加了hint的话则会出现多个V$SQL记录,说明V$SQL对应的sql语句必须一模一样,如果altersystemflushshared_pool(主站慎用)后再执行一样的语句,发现语句在V$SQL中的SQL_ID和HASH_VALUE与之前的一样,说明SQL_ID和HASH_VALUE应该是oracle自己的一套算法来的,只是根据sql语句内容来进行转换,sql语句不变则SQL_ID和HASH_VALUE也不变。)
  第一种
  select*from(
  selectcount(*),sql_id,substr(sql_text,1,40)
  fromv$sql
  groupbysql_id,substr(sql_text,1,40)havingcount(*)>10orderbycount(*)desc)whererownum<10
  第二种
  count(1)>10表示类语句运行了10次以上
  selectsql_id,FORCE_MATCHING_SIGNATURE,sql_text
  fromv$SQL
  whereFORCE_MATCHING_SIGNATUREin
  (select/*+unnest*/
  FORCE_MATCHING_SIGNATURE
  fromv$sql
  whereFORCE_MATCHING_SIGNATURE>0
  andFORCE_MATCHING_SIGNATURE!=EXACT_MATCHING_SIGNATURE
  groupbyFORCE_MATCHING_SIGNATURE
  havingcount(1)>10)
  22、查看数据文件可用百分比
  selectb.file_id,b.tablespace_name,b.file_name,b.AUTOEXTENSIBLE,
  ROUND(b.bytes/1024/1024/1024,2)||'G'"文件总容量",
  ROUND((b.bytes-sum(nvl(a.bytes,0)))/1024/1024/1024,2)||'G'"文件已用容量",
  ROUND(sum(nvl(a.bytes,0))/1024/1024/1024,2)||'G'"文件可用容量",
  ROUND(sum(nvl(a.bytes,0))/(b.bytes),2)*100||'%'"文件可用百分比"
  fromdba_free_spacea,dba_data_filesb
  wherea.file_id=b.file_id
  groupbyb.tablespace_name,b.file_name,b.file_id,b.bytes,b.AUTOEXTENSIBLE
  orderbyb.tablespace_name;
  23、查看数据文件可用百分比
  selectb.file_id,b.tablespace_name,b.file_name,b.AUTOEXTENSIBLE,
  ROUND(b.MAXBYTES/1024/1024/1024,2)||'G'"文件最大可用总容量",
  ROUND((b.bytes-sum(nvl(a.bytes,0)))/1024/1024/1024,2)||'G'"文件已用容量",
  ROUND(((b.MAXBYTES/1024/1024/1024)-((b.bytes-sum(nvl(a.bytes,0)))/1024/1024/1024))/(b.MAXBYTES/1024/1024/1024),2)*100||'%'"文件可用百分比"
  fromdba_free_spacea,dba_data_filesb
  wherea.file_id=b.file_idandb.file_id>4
  groupbyb.tablespace_name,b.file_name,b.file_id,b.bytes,b.AUTOEXTENSIBLE,b.MAXBYTES
  orderbyb.tablespace_name;
  24、查看表空间可用百分比
  selectb.tablespace_name,a.total,b.free,round((b.free/a.total)*100)"%Free"from
  (selecttablespace_name,sum(bytes/(1024*1024))totalfromdba_data_filesgroupbytablespace_name)a,
  (selecttablespace_name,round(sum(bytes/(1024*1024)))freefromdba_free_spacegroupbytablespace_name)b
  WHEREa.tablespace_name=b.tablespace_name
  orderby"%Free";
  25、查看临时表空间使用率
  SELECTtemp_used.tablespace_name,total,used,
  total-usedas"Free",
  round(nvl(total-used,0)*100/total,3)"Freepercent"
  FROM(SELECTtablespace_name,SUM(bytes_used)/1024/1024used
  FROMGV_$TEMP_SPACE_HEADER
  GROUPBYtablespace_name)temp_used,
  (SELECTtablespace_name,SUM(bytes)/1024/1024total
  FROMdba_temp_files
  GROUPBYtablespace_name)temp_total
  WHEREtemp_used.tablespace_name=temp_total.tablespace_name
  26、查询undo表空间使用情况
  selecttablespace_name,status,sum(bytes)/1024/1024Mfromdba_undo_extentsgroupbytablespace_name,status
  27、查看ASM磁盘组使用率
  selectname,round(total_mb/1024)"总容量",round(free_mb/1024)"空闲空间",round((free_mb/total_mb)*100)"可用空间比例"fromgv$asm_diskgroup
  28、统计每个用户使用表空间率
  SELECTc.owner"用户",
  a.tablespace_name"表空间名",
  total/1024/1024"表空间大小M",
  free/1024/1024"表空间剩余大小M",
  (total-free)/1024/1024"表空间使用大小M",
  Round((total-free)/total,4)*100"表空间总计使用率%",
  c.schemas_use/1024/1024"用户使用表空间大小M",
  round((schemas_use)/total,4)*100"用户使用表空间率%"
  FROM(SELECTtablespace_name,
  Sum(bytes)free
  FROMDBA_FREE_SPACE
  GROUPBYtablespace_name)a,
  (SELECTtablespace_name,
  Sum(bytes)total
  FROMDBA_DATA_FILES
  GROUPBYtablespace_name)b,
  (Selectowner,Tablespace_Name,
  Sum(bytes)schemas_use
  FromDba_Segments
  GroupByowner,Tablespace_Name)c
  WHEREa.tablespace_name=b.tablespace_name
  anda.tablespace_name=c.Tablespace_Name
  orderby"用户","表空间名"
  29、查看闪回区/快速恢复区空间使用率
  selectsum(percent_space_used)||'%'"已使用空间比例"fromV$RECOVERY_AREA_USAGE
  30、查看僵死进程,分两种
  altersystemkillsession一执行则session即标记为KILLED,但是如果会话产生的数据量大则这个kill可能会比较久,在这个过程中session标记为KILLED但是这个会话还在V$session中,则V$session.paddr还在,所以可以匹配到V$process.addr,所以process进程还在;当kill过程执行完毕,则这个会话即不在V$session中
  会话不在的
  select*fromv$processwhereaddrnotin(selectpaddrfromv$session)andpidnotin(1,17,18)
  会话还在的,但是会话标记为killed
  select*fromv$processwhereaddrin(selectpaddrfromv$sessionwherestatus='KILLED')
  再根据上述结果中的SPID通过如下命令可以查看到process的启动时间
  psauxw|head-1;psauxw|grepSPID
  31、查看行迁移或行链接的表
  select*Fromdba_tableswherenvl(chain_cnt,0)<>0
  chain_cnt:Numberofrowsinthetablethatarechainedfromonedatablocktoanotherorthathavemigratedtoanewblock,requiringalinktopreservetheoldrowid.Thiscolumnisupdatedonlyafteryouanalyzethetable.
  32、数据缓冲区命中率
  LECTa.VALUE+b.VALUElogical_reads,c.VALUEphys_reads,
  round(100*(1-c.value/(a.value+b.value)),2)||'%'hit_ratio
  FROMv$sysstata,v$sysstatb,v$sysstatc
  WHEREa.NAME='dbblockgets'
  ANDb.NAME='consistentgets'
  ANDc.NAME='physicalreads';
  或
  SELECTDB_BLOCK_GETS+CONSISTENT_GETSLogical_reads,PHYSICAL_READSphys_reads,
  round(100*(1-(PHYSICAL_READS/(DB_BLOCK_GETS+CONSISTENT_GETS))),2)||'%'"HitRatio"
  FROMV$BUFFER_POOL_STATISTICSWHERENAME='DEFAULT';
  33、共享池命中率
  以下两者应该都可以,看个人怎么理解
  selectsum(pinhits)/sum(pins)*100fromv$librarycache;
  selectsum(pinhits-reloads)/sum(pins)*100fromv$librarycache;
  34、查询归档日志切换频率
  selectsequence#,to_char(first_time,'yyyymmdd_hh24:mi:ss')
  firsttime,round((first_time-lag(first_time)over(orderbyfirst_time))*24*60,2)minutesfrom
  v$log_historywherefirst_time>sysdate-3orderbyfirst_time,minutes;
  或
  selectsequence#,to_char(first_time,'yyyy-mm-ddhh24:mi:ss')First_time,First_change#,switch_change#from
  v$loghistwherefirst_time>sysdate-3orderby1;
  35、查询lgwr进程写日志时每执行一次lgwr需要多少秒,在state是waiting的情况下,某个等待编号seq#下,seconds_in_wait达多少秒,就是lgwr进程写一次IO需要多少秒
  selectevent,state,seq#,seconds_in_wait,programfromv$sessionwhereprogramlike'%LGWR%'andstate='WAITING'
  36、查询没有索引的表
  Selecttable_namefromuser_tableswheretable_namenotin(selecttable_namefromuser_indexes)
  Selecttable_namefromuser_tableswheretable_namenotin(selecttable_namefromuser_ind_columns)
  37、查询7天的dbtime
  THsysstatAS
  (selectsn.begin_interval_timebegin_interval_time,
  sn.end_interval_timeend_interval_time,
  ss.stat_namestat_name,
  ss.valuee_value,
  lag(ss.value,1)over(orderbyss.snap_id)b_value
  fromdba_hist_sysstatss,dba_hist_snapshotsn
  wheretrunc(sn.begin_interval_time)>=sysdate-7
  andss.snap_id=sn.snap_id
  andss.dbid=sn.dbid
  andss.instance_number=sn.instance_number
  andss.dbid=(selectdbidfromv$database)
  andss.instance_number=(selectinstance_numberfromv$instance)
  andss.stat_name='DBtime')
  selectto_char(BEGIN_INTERVAL_TIME,'mm-ddhh24:mi')||
  to_char(END_INTERVAL_TIME,'hh24:mi')date_time,
  stat_name,
  round((e_value-nvl(b_value,0))/
  (extract(dayfrom(end_interval_time-begin_interval_time))*24*60*60+
  extract(hourfrom(end_interval_time-begin_interval_time))*60*60+
  extract(minutefrom(end_interval_time-begin_interval_time))*60+
  extract(secondfrom(end_interval_time-begin_interval_time))),
  0)per_sec
  fromsysstat
  where(e_value-nvl(b_value,0))>0
  andnvl(b_value,0)>0
  38、查询产生热块较多的对象
  x$bh.tch(Touch)表示访问次数越高,热点快竞争问题就存在
  SELECTe.owner,e.segment_name,e.segment_type
  FROMdba_extentse,
  (SELECT*
  FROM(SELECTaddr,ts#,file#,dbarfil,dbablk,tch
  FROMx$bh
  ORDERBYtchDESC)
  WHEREROWNUM<11)b
  WHEREe.relative_fno=b.dbarfil
  ANDe.block_id<=b.dbablk
  ANDe.block_id+e.blocks>b.dbablk;
  39、导出AWR报告的SQL语句
  select*fromdba_hist_snapshot
  select*fromtable(dbms_workload_repository.awr_report_html(DBID,INSTANCE_NUMBER,startsnapid,endsnapid))
  select*fromTABLE(DBMS_WORKLOAD_REPOSITORY.awr_diff_report_html(DBID,INSTANCE_NUMBER,startsnapid,endsnapid,DBID,INSTANCE_NUMBER,startsnapid,endsnapid));
  40、查询某个SQL的执行计划
  selecta.hash_value,a.*fromv$sqlawheresql_id='0n4qfzbqfsjm3'
  select*fromtable(dbms_xplan.display_cursor(v$sql.hash_value,0,'advanced'));
  含顺序的
  select*fromtable(xplan.display_cursor('v$sql.sql_id',0,'advanced'));
  不过要先创建xplan包,再执行
  SQL>CREATEPUBLICSYNONYMXPLANFORSYS.XPLAN;
  SQL>grantexecuteonsys.xplantopublic;
  • 北京校区
  • 山西校区
  • 郑州校区
  • 武汉校区
  • 四川校区
  • 长沙校区
  • 深圳校区
  • 上海校区
  • 广州校区
  • 保定招生办

北京海淀区校区(总部):北京市海淀区西三旗街道建材城西路中腾建华商务大厦东侧二层尚学堂
北京京南校区:北京亦庄经济开发区科创十四街6号院1号楼 赛蒂国际工业园
咨询电话:400-009-1906 / 010-56233821
面授课程: JavaEE培训大数据就业班培训大数据云计算周末班培训零基础大数据连读班培训大数据云计算高手班培训人工智能周末班培训人工智能+Python全栈培训H5+PHP全栈工程师培训

山西学区地址:山西省晋中市榆次区大学城大学生活广场万科商业A1座702
咨询电话:0354-3052381 / 18903441162

郑州学区地址:金水区东风路经三路北100米注协大厦10楼
咨询电话:0371-55177956 

武汉学区地址:湖北省武汉市江夏区江夏大道26号 宏信悦谷创业园4楼
咨询电话:027-87989193

四川学区地址:成都市高新区锦晖西一街99号布鲁明顿大厦2栋1003室
咨询电话:028-65176856 / 13880900114

长沙学区地址:长沙市岳麓区麓源路湖南电子商务基地5楼(公交车站:六沟垅)
咨询电话:0731-83072091

深圳校区地址:深圳市宝安区航城街道航城大道航城创新创业园A4栋210(固戍地铁站C出口)
咨询电话:0755-23061965 / 18898413781

上海尚学堂松江校区地址:上海市松江区荣乐东路2369弄45号绿地伯顿大厦2层
咨询电话:021-67690939

广州校区地址:广州市天河区元岗横路31号慧通产业广场B区B1栋6楼尚学堂(地铁3号线或6号线到“天河客运站”D出口,右拐直走约800米)
咨询电话:020-2989 6995

保定招生办公室

地址:河北省保定市竞秀区朝阳南大街777号鸿悦国际1101室

电话:15132423123

Copyright 2006-2018 北京尚学堂科技有限公司  京ICP备13018289号-19  京公网安备11010802015183  
媒体联系:18610174079 闫老师  

有位老师想和您聊一聊