oracle中常见ck和fk是什么,Oracle常用知识总结
1.曾经不小心把开发库的数据库表全部删除,当时吓的要死。结果找到下面的语句恢复到了1个小时之前的数据!很简单。
注意使用管理员登录系统:
select * from 表名 as of timestamp
sysdate-1/12 //查询两个小时前的某表数据!既然两小时以前的数据都得到了,继续怎么做,知道了吧。。
如果drop了表,怎么办??见下面:
drop table 表名;
数据库误删除表之后恢复,不过要记得删除了哪些表名。
flashback table 表名
to before drop;
2.查询得到当前数据库中锁,以及解锁:
查锁
SELECT s.username,
decode(l.type,'TM','TABLE
LOCK',
'TX','ROW LOCK',
NULL) LOCK_LEVEL,
o.owner,o.object_name,o.object_type,
s.sid,s.serial#,s.terminal,s.machine,s.program,s.osuser
FROM v$session s,v$lock l,dba_objects
o
WHERE l.sid = s.sid
AND l.id1 = o.object_id(+)
AND s.username is NOT NULL;
解锁
alter system kill session
'sid,serial';
如果解不了。直接倒os下kill进程kill -9 spid
ORA-28000:账户被锁定
因为密码输入错误多次用户自动被锁定.
解决办法:alter user user_name account
unlock;
3.关于查询数据库用户,权限的相关语句:
查看所有用户:
select * from
dba_user;
select * from
all_users;
select * from
user_users;
查看用户系统权限:
select * from
dba_sys_privs;
select * from
all_sys_privs;
10.select * from
user_sys_privs;
查看用户对象权限:
select * from
dba_tab_privs;
select * from
all_tab_privs;
select * from
user_tab_privs;
查看所有角色:
20.select * from
dba_roles;
查看用户所拥有的角色:
select * from
dba_role_privs;
select * from
user_role_privs;
几个经常用到的oracle视图:注意表名使用大写....................
查询oracle中所有用户信息
select *
from dba_user;
只查询用户和密码
select
username,password from
dba_users;
查询当前用户信息
select
* from dba_ustats;
查询用户可以访问的视图文本
select
* from dba_varrays;
查询数据库中所有视图的文本
select
* from dba_views;
查询全部索引
select * from
user_indexes;
查询全部表格
select
* from user_tables;
查询全部约束
select
* from
user_constraints;
查询全部对象
select
* from user_objects;
查看当前数据库中正在执行的语句,然后可以继续做很多很多事情,例如查询执行计划等等
(1).查看相关进程在数据库中的会话
Select a.sid,a.serial#,a.program, a.status ,
substr(a.machine,1,20), a.terminal,b.spid
from v$session a, v$process b
where a.paddr=b.addr
and b.spid = &spid;
(2).查看数据库中被锁住的对象和相关会话
select a.sid,a.serial#,a.username,a.program,
c.owner, c.object_name
from v$session a, v$locked_object b, all_objects c
where a.sid=b.session_id and
c.object_id = b.object_id;
(3).查看相关会话正在执行的SQL
select sql_text from v$sqlarea where address =
( select sql_address from v$session where sid = &sid );
(1).查看相关进程在数据库中的会话
Select a.sid,a.serial#,a.program, a.status ,
substr(a.machine,1,20), a.terminal,b.spid
from v$session a, v$process b
where a.paddr=b.addr
and b.spid = &spid;
(2).查看数据库中被锁住的对象和相关会话
select a.sid,a.serial#,a.username,a.program,
c.owner, c.object_name
from v$session a, v$locked_object b, all_objects c
where a.sid=b.session_id and
c.object_id = b.object_id;
(3).查看相关会话正在执行的SQL
select sql_text from v$sqlarea where address =
( select sql_address from v$session where sid = &sid );
查询表的结构:表名大写!!
select t.COLUMN_NAME,
t.DATA_TYPE,
nvl(t.DATA_PRECISION,
t.DATA_LENGTH),
nvl(T.DATA_SCALE,
0),
c.comments
from
all_tab_columns t, user_col_comments c
whEre t.TABLE_NAME =
c.table_name
and
t.COLUMN_NAME = c.column_name
and
t.TABLE_NAME = UPPER('OM_EMPLOYEE_T')
order by
t.COLUMN_ID
行列互换:
Sql代码
建立一个例子表:
CREATE TABLE
t_col_row(
ID
INT,
c1
VARCHAR2(10),
c2
VARCHAR2(10),
c3
VARCHAR2(10));
INSERT INTO t_col_row VALUES (1, 'v11',
'v21',
'v31');
INSERT INTO t_col_row VALUES (2, 'v12',
'v22',
NULL);
INSERT INTO t_col_row VALUES (3, 'v13',
NULL,
'v33');
INSERT INTO t_col_row VALUES (4, NULL,
'v24',
'v34');
INSERT INTO t_col_row VALUES (5, 'v15',
NULL,
NULL);
INSERT INTO t_col_row VALUES (6, NULL,
NULL,
'v35');
INSERT INTO t_col_row VALUES (7, NULL,
NULL,
NULL);
COMMIT;
下面的是列转行:创建了一个视图
CREATE view v_row_col
AS
SELECT id, 'c1' cn, c1
cv
FROM
t_col_row
UNION
ALL
SELECT id, 'c2' cn, c2
cv
FROM
t_col_row
UNION
ALL
SELECT id, 'c3' cn, c3 cv FROM
t_col_row;
下面是创建了没有空值的一个竖表:
CREATE view v_row_col_notnull
AS
SELECT id, 'c1' cn, c1
cv
FROM
t_col_row
where c1 is not
null
UNION
ALL
SELECT id, 'c2' cn, c2
cv
FROM
t_col_row
where c2 is not
null
UNION
ALL
SELECT id, 'c3' cn, c3
cv
FROM
t_col_row
where c3 is not
null;
Sql代码
建立一个例子表:
CREATE TABLE
t_col_row(
ID
INT,
c1
VARCHAR2(10),
c2
VARCHAR2(10),
c3
VARCHAR2(10));
INSERT INTO t_col_row VALUES (1, 'v11',
'v21',
'v31');
INSERT INTO t_col_row VALUES (2, 'v12',
'v22',
NULL);
INSERT INTO t_col_row VALUES (3, 'v13',
NULL,
'v33');
INSERT INTO t_col_row VALUES (4, NULL,
'v24',
'v34');
INSERT INTO t_col_row VALUES (5, 'v15',
NULL,
NULL);
INSERT INTO t_col_row VALUES (6, NULL,
NULL,
'v35');
INSERT INTO t_col_row VALUES (7, NULL,
NULL,
NULL);
COMMIT;
下面的是列转行:创建了一个视图
CREATE view v_row_col
AS
SELECT id, 'c1' cn, c1
cv
FROM
t_col_row
UNION ALL
SELECT id, 'c2' cn, c2
cv
FROM
t_col_row
UNION ALL
SELECT id, 'c3' cn, c3 cv FROM
t_col_row;
下面是创建了没有空值的一个竖表:
CREATE view v_row_col_notnull
AS
SELECT id, 'c1' cn, c1
cv
FROM
t_col_row
where c1 is not
null
UNION ALL
SELECT id, 'c2' cn, c2
cv
FROM
t_col_row
where c2 is not
null
UNION ALL
SELECT id, 'c3' cn, c3
cv
FROM
t_col_row
where c3 is not
null;
建立一个例子表:
CREATE TABLE t_col_row(
ID INT,
c1 VARCHAR2(10),
c2 VARCHAR2(10),
c3 VARCHAR2(10));
INSERT INTO t_col_row VALUES (1, 'v11',
'v21', 'v31');
INSERT INTO t_col_row VALUES (2, 'v12',
'v22', NULL);
INSERT INTO t_col_row VALUES (3, 'v13',
NULL, 'v33');
INSERT INTO t_col_row VALUES (4, NULL,
'v24', 'v34');
INSERT INTO t_col_row VALUES (5, 'v15',
NULL, NULL);
INSERT INTO t_col_row VALUES (6, NULL,
NULL, 'v35');
INSERT INTO t_col_row VALUES (7, NULL,
NULL, NULL);
COMMIT;
下面的是列转行:创建了一个视图
CREATE view v_row_col AS
SELECT id, 'c1' cn, c1 cv
FROM t_col_row
UNION ALL
SELECT id, 'c2' cn, c2 cv
FROM t_col_row
UNION ALL
SELECT id, 'c3' cn, c3 cv FROM
t_col_row;
下面是创建了没有空值的一个竖表:
CREATE view v_row_col_notnull
AS
SELECT id, 'c1' cn, c1 cv
FROM
t_col_row
where c1 is not null
UNION ALL
SELECT id, 'c2' cn, c2 cv
FROM
t_col_row
where c2 is not null
UNION ALL
SELECT id, 'c3' cn, c3 cv
FROM
t_col_row
where c3 is not null;
下面可能是dba经常使用的oracle视图吧。呵呵
Sql代码
示例:已知hash_value:3111103299,查询sql语句:
select * from
v$sqltext
where
hashvalue='3111103299'
order by
piece
查看消耗资源最多的SQL:
SELECT hash_value, executions,
buffer_gets, disk_reads,
parse_calls
FROM
V$SQLAREA
WHERE buffer_gets > 10000000OR
disk_reads >
1000000
ORDERBY buffer_gets + 100 * disk_reads
DESC;
查看某条SQL语句的资源消耗:
SELECT hash_value, buffer_gets,
disk_reads, executions,
parse_calls
FROM
V$SQLAREA
WHERE hash_Value = 228801498AND address =
hextoraw('CBD8E4B0');
查询sql语句的动态执行计划:
首先使用下面的语句找到语句的在执行计划中的address和hash_code
SELECT
sql_text, address, hash_value FROM v$sql
t
where
(sql_text like
'%FUNCTION_T(表名大写!)%')
然后:
SELECT
operation, options, object_name, cost FROM
v$sql_plan
WHERE
address = 'C00000016BD6D248' AND hash_value =
664376056;
查询oracle的版本:
select * from
v$version;
查询数据库的一些参数:
select * from
v$parameter
查找你的session信息
SELECT SID, OSUSER, USERNAME, MACHINE,
PROCESS
FROM V$SESSION WHERE audsid =
userenv('SESSIONID');
当machine已知的情况下查找session
SELECT SID, OSUSER, USERNAME, MACHINE,
TERMINAL
FROM
V$SESSION
WHERE terminal = 'pts/tl' AND machine =
'rgmdbs1';
查找当前被某个指定session正在运行的sql语句。假设sessionID为100
select
b.sql_text
from v$session a,v$sqlarea
b
where a.sql_hashvalue=b.hash_value and
a.sid=100
Sql代码
示例:已知hash_value:3111103299,查询sql语句:
select * from
v$sqltext
where
hashvalue='3111103299'
order by
piece
查看消耗资源最多的SQL:
SELECT hash_value, executions,
buffer_gets, disk_reads,
parse_calls
FROM
V$SQLAREA
WHERE buffer_gets > 10000000OR
disk_reads >
1000000
ORDERBY buffer_gets + 100 * disk_reads
DESC;
查看某条SQL语句的资源消耗:
SELECT hash_value, buffer_gets,
disk_reads, executions,
parse_calls
FROM
V$SQLAREA
WHERE hash_Value = 228801498AND address =
hextoraw('CBD8E4B0');
查询sql语句的动态执行计划:
首先使用下面的语句找到语句的在执行计划中的address和hash_code
SELECT
sql_text, address, hash_value FROM v$sql
t
where
(sql_text like
'%FUNCTION_T(表名大写!)%')
然后:
SELECT
operation, options, object_name, cost FROM
v$sql_plan
WHERE
address = 'C00000016BD6D248' AND hash_value =
664376056;
查询oracle的版本:
select * from
v$version;
查询数据库的一些参数:
select * from
v$parameter
查找你的session信息
SELECT SID, OSUSER, USERNAME, MACHINE,
PROCESS
FROM V$SESSION WHERE audsid =
userenv('SESSIONID');
当machine已知的情况下查找session
SELECT SID, OSUSER, USERNAME, MACHINE,
TERMINAL
FROM
V$SESSION
WHERE terminal = 'pts/tl' AND machine =
'rgmdbs1';
查找当前被某个指定session正在运行的sql语句。假设sessionID为100
select
b.sql_text
from v$session a,v$sqlarea
b
where a.sql_hashvalue=b.hash_value and
a.sid=100
示例:已知hash_value:3111103299,查询sql语句:
select * from v$sqltext
where hashvalue='3111103299'
order by piece
查看消耗资源最多的SQL:
SELECT hash_value, executions,
buffer_gets, disk_reads, parse_calls
FROM V$SQLAREA
WHERE buffer_gets > 10000000OR
disk_reads > 1000000
ORDERBY buffer_gets + 100 * disk_reads
DESC;
查看某条SQL语句的资源消耗:
SELECT hash_value, buffer_gets,
disk_reads, executions, parse_calls
FROM V$SQLAREA
WHERE hash_Value = 228801498AND address =
hextoraw('CBD8E4B0');
查询sql语句的动态执行计划:
首先使用下面的语句找到语句的在执行计划中的address和hash_code
SELECT
sql_text, address, hash_value FROM v$sql t
where
(sql_text like '%FUNCTION_T(表名大写!)%')
然后:
SELECT
operation, options, object_name, cost FROM v$sql_plan
WHERE
address = 'C00000016BD6D248' AND hash_value = 664376056;
查询oracle的版本:
select * from v$version;
查询数据库的一些参数:
select * from v$parameter
查找你的session信息
SELECT SID, OSUSER, USERNAME, MACHINE,
PROCESS
FROM V$SESSION WHERE audsid =
userenv('SESSIONID');
当machine已知的情况下查找session
SELECT SID, OSUSER, USERNAME, MACHINE,
TERMINAL
FROM V$SESSION
WHERE terminal = 'pts/tl' AND machine =
'rgmdbs1';
查找当前被某个指定session正在运行的sql语句。假设sessionID为100
select b.sql_text
from v$session a,v$sqlarea b
where a.sql_hashvalue=b.hash_value and
a.sid=100
树形结构connect by 排序:
Sql代码
查询树形的数据结构,同时对一层里面的数据进行排序
SELECT last_name, employee_id, manager_id,
LEVEL
FROM
employees
START
WITH employee_id =
100
CONNECT
BY PRIOR employee_id =
manager_id
ORDER SIBLINGS BY
last_name;
下面是查询结果
LAST_NAME EMPLOYEE_ID
MANAGER_ID LEVEL
------------------------- -----------
----------
----------
King 100 1
Cambrault 148 100 2
Bates 172 148 3
Bloom 169 148 3
Fox 170 148 3
Kumar 173 148 3
Ozer 168 148 3
Smith 171 148 3
De
Haan 102 100 2
Hunold 103 102 3
Austin 105 103 4
Ernst 104 103 4
Lorentz 107 103 4
Pataballa 106 103 4
Errazuriz 147 100 2
Ande 166 147 3
Banda 167 147 3
Sql代码
查询树形的数据结构,同时对一层里面的数据进行排序
SELECT last_name, employee_id, manager_id,
LEVEL
FROM
employees
START
WITH employee_id =
100
CONNECT
BY PRIOR employee_id =
manager_id
ORDER SIBLINGS BY
last_name;
下面是查询结果
LAST_NAME EMPLOYEE_ID
MANAGER_ID LEVEL
------------------------- -----------
----------
----------
King 100 1
Cambrault 148 100 2
Bates 172 148 3
Bloom 169 148 3
Fox 170 148 3
Kumar 173 148 3
Ozer 168 148 3
Smith 171 148 3
De
Haan 102 100 2
Hunold 103 102 3
Austin 105 103 4
Ernst 104 103 4
Lorentz 107 103 4
Pataballa 106 103 4
Errazuriz 147 100 2
Ande 166 147 3
Banda 167 147 3
查询树形的数据结构,同时对一层里面的数据进行排序
SELECT last_name, employee_id, manager_id,
LEVEL
FROM
employees
START
WITH employee_id = 100
CONNECT
BY PRIOR employee_id = manager_id
ORDER
SIBLINGS BY last_name;
下面是查询结果
LAST_NAME EMPLOYEE_ID
MANAGER_ID LEVEL
------------------------- -----------
---------- ----------
King 100 1
Cambrault 148 100 2
Bates 172 148 3
Bloom 169 148 3
Fox 170 148 3
Kumar 173 148 3
Ozer 168 148 3
Smith 171 148 3
De
Haan 102 100 2
Hunold 103 102 3
Austin 105 103 4
Ernst 104 103 4
Lorentz 107 103 4
Pataballa 106 103 4
Errazuriz 147 100 2
Ande 166 147 3
Banda 167 147 3
有时候写多了东西,居然还忘记最基本的sql语法,下面全部写出来,基本的oracle语句都在这里可以找到了。是很基础的语句!
Sql代码
在数据字典查询约束的相关信息:
SELECT constraint_name,
constraint_type,search_condition
FROM user_constraints
WHERE table_name
=
'EMPLOYEES';
//这里的表名都是大写!
2对表结构进行说明:
desc
Tablename
3查看用户下面有哪些表
select
table_name from
user_tables;
4查看约束在那个列上建立:
SELECT
constraint_name,
column_name
FROM user_cons_columns
WHERE table_name
=
'EMPLOYEES';
10结合变量查找相关某个表中约束的相关列名:
select
constraint_name,column_name from user_cons_columns where table_name
= '&tablename'
12查询数据字典看中间的元素:
SELECT object_name,
object_type
FROM user_objects
WHERE object_name
LIKE
'EMP%'
OR object_name
LIKE 'DEPT%'
14查询对象类型:
SELECT DISTINCT object_type
FROM user_objects
;
17改变对象名:(表名,视图,序列)
rename emp
to
emp_newTable
18添加表的注释:
COMMENT ON
TABLE employees IS 'Employee
Information';
20查看视图结构:
describe
view_name
23在数据字典中查看视图信息:
select
viewe_name,text from
user_views
25查看数据字典中的序列:
select
* from
user_sequences
33得到所有的时区名字信息:
select *
from
v$timezone_names
34显示对时区‘US/Eastern’的时区偏移量
select
TZ_OFFSET('US/Eastern') from
DUAL--dual英文意思是‘双重的’
显示当前会话时区中的当前日期和时间:
ALTER
SESSION SET NLS_DATE_FORMAT = 'DD-MON-YYYY
HH24:MI:SS';--修改显示时间的方式的设置
ALTER
SESSION SET TIME_ZONE =
'-5:0';--修改时区
SELECT
SESSIONTIMEZONE, CURRENT_DATE FROM
DUAL;--真正有用的语句!
SELECT
CURRENT_TIMESTAMP FROM
DUAL;--返回的时间是当前日期和时间,含有时区
SELECT
CURRENT_TIMESTAMP FROM
DUAL;--返回的时间是当前日期和时间,不含有时区!!!
35显示数据库时区和会话时区的值:
select
datimezone,sessiontimezone from
dual;
13普通的建表语句:
CREATE TABLE
dept
(deptno NUMBER(2),
dname VARCHAR2(14),
loc VARCHAR2(13));
15使用子查询建立表:
CREATE
TABLE dept80
AS SELECT employee_id,
last_name,
salary*12
ANNSAL,
hire_date FROM employees WHERE department_id
=
80;
6添加列:// alter table EMP add column
(dept_id
number(7));错误!!
alter
table EMP add (dept_id
number(7));
7删除一列:
alter
table emp drop column
dept_id;
8添加列名同时和约束:
alter table EMP add
(dept_id
number(7)
constraint
my_emp_dept_id_fk references
dept(ID));
9改变列://注意约束不能够修改
的!!
alter table dept80
modify(last_name
varchar2(30));//这里使用的是modify而不是alter!
24增加一行:
insert
into table_name
values();
5添加主键:
alter Table
EMP add constraint my_emp_id_pk
primary key
(ID);
11添加一个有check约束的新列:
alter
table
EMP
add
(COMMISSION number(2) constraint emp_commission_ck
check(commission>0))
16删除表:
drop
table
emp;
19创建视图:
CREATE
VIEW empvu80
AS
SELECT employee_id, last_name,
salary
FROM employees WHERE department_id
=
80;
21删除视图:
drop
view
view_name
22找到工资最高的5个人。(top-n分析)(行内视图)
select
rownum,employee_id from (select employee_id,salary
from
employees order by
salary
desc)
where
rownum<5;
26建立同义词:
create
synonym 同义词名 for
原来的名字
或者 create
public synonym 同义词名 for
原来的名字
27建立序列:(注意,这里并没有出现说是哪个表里面的序列!!)
CREATE
SEQUENCE
dept_deptid_seq
INCREMENT
BY
10
START
WITH
120
MAXVALUE
9999
NOCACHE
NOCYCLE
28使用序列:
insert
into dept(ID,NAME)
values(DEPT_ID_SEQ.nextval,'Administration');
29建立索引://默认就是nonunique索引,除非使用了关键字:unique
CREATE
INDEX emp_last_name_idx ON
employees(last_name);
30建立用户:(可能有错,详细查看帮助)
create
user username(用户名)
identified
by
oracle(密码)
default
tablespace data01(表空间名//默认存在system表空间里面)
q
来源:
oracle中常见ck和fk是什么,Oracle常用知识总结相关推荐
- oracle中常见ck和fk是什么,oracle知识整理
额滴数据库太薄弱了,整理一下知识点吧: 外键(foreign key)约束: 在建表之后,为表增加外键约束可以像下面这样操作: 为表增加外键约束: 1.alert table student 2.ad ...
- oracle 的exp是什么,oracle中exp和imp是什么,oracle中exp和imp有何区别 | 学步园
oracle中exp和imp是什么,oracle中exp和imp有何区别.exp和imp的输入都是名字和值对:exp parameter_name=value 或exp parameter_name= ...
- Oracle中常见的Hint(一)
Oracle中的Hint可以用来调整SQL的执行计划,提高SQL执行效率.下面分类介绍Oracle数据库中常见的Hint.这里描述的是Oracle11gR2中的常见Hint,Oracle数据库中各个版 ...
- oracle中如何创建一个过程,如何开发ORACLE存储过程
一. 概述 Oracle存储过程开发的要点是: • 使用Notepad文本编辑器,用Oracle PL/SQL编程语言写一个存储过程; • 在Oracle数据库中创建一个存储过程; • 在Oracle ...
- oracle中存储过程和函数有什么区别,Oracle中存储过程和函数的区别
Oracle中存储过程和函数的区别 存储过程和函数: www.2cto.com 例子: [sql] //创建过程 create or replace procedure add_emailinfo( ...
- oracle中overwrite写法,【学习笔记】Oracle 11G新特性restart的深入研究案例
[学习笔记]Oracle 11G新特性restart的深入研究案例 时间:2016-11-26 22:35 来源:Oracle研究中心 作者:网络 点击: 次 天萃荷净 Oracle研究中 ...
- oracle中in函数在子查询使用,Oracle In
oracle函数 的 Oracle In 在本教程中,您将学习如何使用Oracle IN运算符来确定值是否与列表或子查询中的任何值相匹配. Oracle IN操作符介绍 Oracle IN运算符确定值 ...
- Oracle中随机抽取N条记录,使用Oracle分析函数随机抽取N条记录
模拟一个歌曲表,有歌曲ID和作者ID,并且初始化一些数据 create table music( music_id int primary key, userid int ); 模拟一个歌曲表,有歌曲 ...
- oracle 表连接 大表小表_优化必备基础:Oracle中常见的三种表连接方式
在Oracle SQL语句中,如果from后面有多个表时,表的连接方式是一个很重要的考量. 从Oracle 6开始,优化器就支持下面4种表连接方式: - 嵌套循环连接(Nested Loop Join ...
最新文章
- Sharepoint 2007 定制Feature和卸载Feature
- stm32锯齿波_工程师实战:基于STM32的波形发生器设计
- fibonacci的几种实现及尾递归
- sharepoint2010 创建自定义列表
- Excel-怎样实现行列转置
- 交互式数据包处理程序 Scapy 入门指南
- SpringCloud 应用在 Kubernetes 上的最佳实践 — 部署篇(工具部署)
- HBase基本操作命令整理
- 功放关键规格参数检查
- 经典面试题(42):以下代码将输出的结果是什么?
- Hbase总结(三)--使用spring-data-hadoop进行hbase的读写操作
- 两平面平行方向向量关系_空间向量,如果一条直线与一平面平行,那么直线的方向向量与平面的法向量有什么关系??垂直呢?...
- 学生考勤及行为管理系统_一种智能学生考勤管理方法及系统与流程
- 发了两个月传单,他转行做了程序员
- 夜思 | 听说你单身?“替代性恋爱”了解一下
- NSString 和 UInt8 相互转换
- 自编译最新稳定版 128M NAND WNDR4300V1 Openwrt Lean固件
- 驾驶员理论考试通过!
- SAP S4HANA1610/Fiori安装过程全记录
- Mandriva 2009 Spring PWP中3D桌面的使用