TOAD使用笔记

1、把鼠标停在sql所在行,然后ctrl+Enter直接执行当前sql。

2、解决Toad对中文显示乱码问题(如果数据库所在主机的NLS_LANG是AMERICAN_AMERICA.WE8ISO8859P1):
系统环境变量加 NLS_LANG=AMERICAN_AMERICA.WE8ISO8859P1

 

3、toad中自动提示功能,就像plsql developer那样:
输入表名前几个字母,然后用Ctrl + .就可以弹出,如你输入select * from emp t where t. 这时候停顿一下,会弹出emp的字段来供你选择

 

4、如何支持代码自动更正,如输入ndf,自动替换成NO_DATA_FOUND,输入sf自动替换成select * from:
点开菜单edit->editer_options->auto_replace中,自己去设定。可以设置任何你想自动替换的单词

 

5、toad如何实现多线程,像plsql developer那样可以取消当前的操作:
安装的时候有选项设置,如果未设置进入view-options-oracle-transactions,把第一个选项选上。

6、在TOAD的SQL Editor中修改查询的数据:
   select rowid,b.* from acc_bill b 就可以修改数据了......

7、使用Object Palette吧,很棒:
在VIEW——Object Palette找到入口。点击后在SQL Editor窗口右侧产生一个窗口,里面可以根据schema选择对象类型,比如table,出现的表名双击后就出现在SQL编辑器里了,下面还有字段名,是不是很方便啊。

8、关于TOAD启动的一些问题:
有的时候安装完成后突然发现无法同时打开两个TOAD,其实这是一个option控制的。进入 option界面,选择General,右侧第四个 “Allow multiple copies ...”,那个就是选项了,打勾后重启程序就可以了。同一个界面里第五个是控制是否显示进入画面,觉得麻烦可以删掉,去掉那个勾就可以了。

9、安装好toad后根据需要使用到的特性,需要运行一些脚本:(都在Toad\temps目录下)
ü 如果需要用Toad来查看执行计划,必须运行脚本PrepToad.sql或者notoad.sql
n 如果希望专门建立一个Toad 用户来存放Toad需要使用的对象的话,就运行preptoad.sql。
n 如果希望在当前连接用户模式下建立toad需要使用的对象的话,就运行notoad.sql。
n 注意,如果是选择了专门建立toad这个用户的话,需要先修改一下脚本,指定用户的默认表空间和临时表空间。
ü 需要使用Oracle8i 的Profile analyzer,必须运行ToadProfiler.sql
ü 需要加强Toad的安全性,必须运行ToadSecurity.sql

10、以下都是指toad8.0xpert下:
执行toad自带的执行计划的方法:
view->options->oracle->general配置explain plan的表名和用户名,如图:

如果还没有建立计划表plan_table请执行以下脚本:
-----------------------------------------------------------------------------
SQL> @C:\oracle\ora92\rdbms\admin\utlxplan.sql
SQL> create public synonym plan_table for plan_table;
SQL> grant select,update,insert,delete on plan_table to public;
-----------------------------------------------------------------------------

11、TOAD 9.0.1.8 版本的几个不错的功能:
Utilities-Unix Job Scheduler 有不少DBA、Backup、Table和Index维护的相关shell脚本,可供学习参考。
Utilities-Network Utilities 有telnet/RExec/Ping/TNSPing/SSH等功能。
Utilities-Script Manager 有不少常用的数据库查询和维护SQL语句,并且能直接执行测试。
View-Object Palette 选上后,会在toad右侧显示数据库对象面板,双击可以在输入区输入对象名,且方便查询。
按F8显示最近执行的sql语句,方便查询,并可选择出来修改、执行。
Database-Compare-Single Objects 可以比较两个对象脚本之间的差异。
Database-Report-HTML Schema Doc Generator 可以生成超文本格式的数据库对象及其代码详细信息文档。
Database-Optimizer-Unix Kernel Parms 计算unix主机(包括Solaris/AIX/HPUX/Tru64/Linux)的内核参数信息。
Database-Optimizer-Repair Chained Rows 可以计算和修复行链接
Database-Optimizer-Rebuild Table 可以生成重建表的脚本(包括索引、约束及其重编译对应存储过程信息)。
Database-Optimizer-Pinned Code 可以查询共享池中的代码信息,并且能Fulsh SGA和pin指定的对象到共享池中。

12、Toad Database Health Check功能执行前操作:
SQL> conn /as sysdba
Connected.
--为了分析alert.log文件
SQL> CREATE OR REPLACE DIRECTORY TOAD_BDUMP_DIR as '/opt/oracle/db01/app/oracle/admin/ORCL/bdump';
Directory created.
SQL> GRANT READ, WRITE on DIRECTORY TOAD_BDUMP_DIR to wacos;
Grant succeeded.
[FK Constraints with nonmatching column definitions]太耗时,建议取消

13、如何设置使得注释字体是立体字而不是斜体字(Toad 9.1.0.62)
编辑区右击 - 选择edit options - 查看Language组合框 - 选择PL/SQL语言 - 点击Edit按钮 - 选择Highlighting标签 - 从左侧Styles里选择Comment - 把Font Style组合框里的Italic选择框的小勾去掉

 

增加swap空间大小

1. 先决定SWAP文件的大小,然后指定区块大小:bs,再指定区块数量count,则SWAP文件的大小是:count*bs
2. 在root用户下执行如下命令:
   [root@OCS_Test root]#dd if=/dev/zero of=/swapfile bs=1024 count=65536
   则产生的文件大小为64M
3. [root@OCS_Test root]#mkswap /swapfile
4. [root@OCS_Test root]#swapon /swapfile
5. 如需在开机时启用该swap,则在/etc/fstab添加如下内容:
   /swapfile    swap           swap    defaults        0 0
6.确认swap已经被使用:
  用free或cat /proc/swaps可察看哪个swap在使用
7.关闭swap
  swapoff /swapfile

linux/arch /home分区 扩容/扩展

今天在我的 virtuabox arch虚拟机下,发现挂在在/home上分区,空间有点不够,由于要装oracle11g吧;so想办法给扩容了一下;

第一步:给我.vdi的虚拟硬盘扩容了一下:仅一条命令

VBoxManage modifyhd <path to your vdi> --resize <new size in megabytes>

第二部:扩容分区

由于我没有使用lvm,所以扩起来有点麻烦:

root 用户下:

cp -a /home /opt/tmp/  ##备份/home分区

fdisk -l

mount

##查看 分区信息,以及文件类型

我的/home分区在 /dev/sda4上 so

fdisk /dev/sda

删除 sda4分区,重新分配一个主分区,空间比较大的,这里我给了8G,记住这里分配给分区标志符,我这里的主分区仍然是/dev/sda4

mkfs.ext2 /dev/sda4 ##格式化这个分区,注意正确的文件类型

vim /etc/fstab/ ##修改,重启后会自动挂载

这里可以用UUID来挂载分区

sudo blkid ## 查看 UUID

这里我碰到了一个问题,由于我没有直接修改/etc/fstab 就重启了,so,arch起来后,文件系统是只读,这是/etc/fstab 就无法直接修改了,从网上查了一下,解决办法:

(1)mount -w -o remount /

(2)然后通过 mount /dev/sda1 /mnt

然后就可以 修改 /etc/fstab

重启后,arch系统正常

将backup的 /home 重新复制 到 /home分区

LVM扩容

在原先的基础上添加了一块20G的硬盘,给lvm分区扩容

#df -h

Filesystem            Size  Used Avail Use% Mounted on
/dev/hda5             7.1G  2.1G  4.7G  31% /
/dev/mapper/VolGroup00-LogVol00
                       12G  159M   11G   2% /home
/dev/hda1              92M   12M   76M  13% /boot
tmpfs                 125M     0  125M   0% /dev/shm

 

#fdisk -l

Disk /dev/hda: 21.4 GB, 21474836480 bytes
255 heads, 63 sectors/track, 2610 cylinders
Units = cylinders of 16065 * 512 = 8225280 bytes

   Device Boot      Start         End      Blocks   Id  System
/dev/hda1   *           1          12       96358+  83  Linux
/dev/hda2              13        1598    12739545   8e  Linux LVM
/dev/hda3            1599        1663      522112+  82  Linux swap / Solaris
/dev/hda4            1664        2610     7606777+   5  Extended
/dev/hda5            1664        2610     7606746   83  Linux

Disk /dev/hdb: 21.4 GB, 21474836480 bytes
15 heads, 63 sectors/track, 44384 cylinders
Units = cylinders of 945 * 512 = 483840 bytes

Disk /dev/hdb doesn't contain a valid partition table

 

很明显/home目录是我们所要扩容的lvm分区,而新添加20G硬盘还未被格式化成LVM格式,现在我们就将他格式化成LVM

#fdisk  /dev/hdb

Device contains neither a valid DOS partition table, nor Sun, SGI or OSF disklabel
Building a new DOS disklabel. Changes will remain in memory only,
until you decide to write them. After that, of course, the previous
content won't be recoverable.


The number of cylinders for this disk is set to 44384.
There is nothing wrong with that, but this is larger than 1024,
and could in certain setups cause problems with:
1) software that runs at boot time (e.g., old versions of LILO)
2) booting and partitioning software from other OSs
   (e.g., DOS FDISK, OS/2 FDISK)
Warning: invalid flag 0x0000 of partition table 4 will be corrected by w(rite)

Command (m for help):n     //创建一个新分区

Command action
   e   extended
   p   primary partition (1-4)

p          //分区编号

Partition number (1-4): 1
First cylinder (1-44384, default 1):                    //起始块,默认为1
Using default value 1
Last cylinder or +size or +sizeM or +sizeK (1-44384, default 44384):                  //结束块,默认最大 
Using default value 44384

Command (m for help):t            //更变分区格式
Selected partition 1
Hex code (type L to list codes):8e          //分区格式代码,L可查看所有编码
Changed system type of partition 1 to 8e (Linux LVM)

 

Command (m for help): p             //打印分区情况

Disk /dev/hdb: 21.4 GB, 21474836480 bytes
15 heads, 63 sectors/track, 44384 cylinders
Units = cylinders of 945 * 512 = 483840 bytes

   Device Boot      Start         End      Blocks   Id  System
/dev/hdb1               1       44384    20971408+  8e  Linux LVM

 

Command (m for help): w               //保存并退出分区
The partition table has been altered!

Calling ioctl() to re-read partition table.

Syncing disks. 

打下面指令可以不用重开机

# partprobe

这样一来格式化分区就做完了,就剩下的任务就是扩容:

首先查看下当前有哪些PV

#pvscan or pvdisplay

/dev/cdrom: open failed: Read-only file system
  Attempt to close device '/dev/cdrom' which is not open.
  PV /dev/hda2   VG VolGroup00   lvm2 [12.12 GB / 0    free]
  Total: 1 [12.12 GB] / in use: 1 [12.12 GB] / in no VG: 0 [0   ]


然后将新划分的/dev/hdb1做成PV

#pvcreate /dev/hdb1

 Physical volume "/dev/hdb1" successfully created

 

再看下,PV的情况

#pvscan or pvdisplay

/dev/cdrom: open failed: Read-only file system
  Attempt to close device '/dev/cdrom' which is not open.
  PV /dev/hda2   VG VolGroup00   lvm2 [12.12 GB / 0    free]
  PV /dev/hdb1   VG VolGroup00   lvm2 [19.97 GB / 19.97 GB free]
  Total: 2 [32.09 GB] / in use: 2 [32.09 GB] / in no VG: 0 [0   ]

 

可以发现新创建的PV还有19.97G空闲,然后给VolGroup00卷组添加剩余的空闲空间

#lvextend -L +19G /dev/VolGroup00/LogVol00

  Extending logical volume LogVol00 to 31.12 GB
  Logical volume LogVol00 successfully resized

 

最后,resize卷组

#resize2fs /dev/VolGroup00/LogVol00
resize2fs 1.39 (29-May-2006)
Filesystem at /dev/VolGroup00/LogVol00 is mounted on /home; on-line resizing required
Performing an on-line resize of /dev/VolGroup00/LogVol00 to 8159232 (4k) blocks.
The filesystem on /dev/VolGroup00/LogVol00 is now 8159232 blocks long.

见证奇迹吧

#df -h
Filesystem            Size  Used Avail Use% Mounted on
/dev/hda5             7.1G  2.1G  4.7G  31% /
/dev/mapper/VolGroup00-LogVol00
                       31G  165M   29G   1% /home
/dev/hda1              92M   12M   76M  13% /boot
tmpfs                 125M     0  125M   0% /dev/shm