随笔 - 72  文章 - 28  trackbacks - 0
<2025年5月>
27282930123
45678910
11121314151617
18192021222324
25262728293031
1234567

常用链接

留言簿(4)

随笔分类(66)

随笔档案(72)

文章档案(19)

收藏夹

搜索

  •  

最新评论

阅读排行榜

评论排行榜

oracle数据库是重量级的,其管理非常复杂,将其在linux平台上的启动和关闭步骤整理一下。

安装完毕oracle以后,需要创建oracle系统用户,并在/home/oracle下面的.bash_profile添加几个环境变量:ORACLE_SID,ORACLE_BASE,ORACLE_HOME。比如:

export ORACLE_SID=test  export ORACLE_BASE=oracle_install_dir export ORACLE_HOME=xxx

启动步骤:注意$代表shell命令提示符,这里的oracle是9.0以上版本。

切换到oracle用户下面:
$ su - oracle

$ sqlplus / nolog

sql> conn / as sysdba

sql> startup (启动数据库,一般不需要加参数,只要设置好环境变量)

sql>shutdown (关闭数据库其参数 :shutdown有四个参数,四个参数的含义如下:
Normal 需要等待所有的用户断开连接
Immediate 等待用户完成当前的语句
Transactional 等待用户完成当前的事务
Abort 不做任何等待,直接关闭数据库
normal需要在所有连接用户断开后才执行关闭数据库任务,所以有的时候看起来好象命令没有运行一样!在执行这个命令后不允许新的连接
immediate在用户执行完正在执行的语句后就断开用户连接,并不允许新用户连接。
transactional 在拥护执行完当前事物后断开连接,并不允许新的用户连接数据库。
abort 执行强行断开连接并直接关闭数据库。

sql> quit (退出sql模式)

启动监听器:

$ su - oracle
然后切换到$oracle_home/bin下面,执行下面命令

$lsnrctl start (启动监听器)
$lsnrctl status (查看监听器启动状态)
$lsnrctl stop(关闭监听器)

 

经常遇到的问题:

1)权限问题,解决方法,切换到oracle用户;

2)没有关闭监听器 ,解决方法:关闭监听器

3)有oracle实例没有关闭,解决办法:关闭oracle实例

4)环境变量设置不全,解决办法:修改环境变量

posted @ 2011-09-26 14:28 kelly 阅读(406) | 评论 (0)编辑 收藏
导出 exp userid/pwdid@servername file=dataname.dmp
导入 imp username/pwdid@servername file=dataname.dmp
Oracle数据导入导出imp/exp就相当于oracle数据还原与备份。exp命令可以把数据从远程数据库服务器导出到本地的dmp文 件,imp命令可以把dmp文件从本地导入到远处的数据库服务器中。 利用这个功能可以构建两个相同的数据库,一个用来测试,一个用来正式使用。

执行环境:可以在SQLPLUS.EXE或者DOS(命令行)中执行,
DOS中可以执行时由于 在oracle 8i 中 安装目录\ora81\BIN被设置为全局路径,
该目录下有EXP.EXE与IMP.EXE文件被用来执行导入导出。
oracle用java编写,SQLPLUS.EXE、EXP.EXE、IMP.EXE这两个文件有可能是被包装后的类文件。
SQLPLUS.EXE调用EXP.EXE、IMP.EXE所包裹的类,完成导入导出功能。

下面介绍的是导入导出的实例。
数据导出:
1 将数据库TEST完全导出,用户名system 密码manager 导出到D:\daochu.dmp中
   exp system/manager@TEST file=d:\daochu.dmp full=y
2 将数据库中system用户与sys用户的表导出
   exp system/manager@TEST file=d:\daochu.dmp owner=(system,sys)
3 将数据库中的表inner_notify、notify_staff_relat导出
    exp aichannel/aichannel@TESTDB2 file= d:\data\newsmgnt.dmp tables=(inner_notify,notify_staff_relat) 

4 将数据库中的表table1中的字段filed1以"00"打头的数据导出
   exp system/manager@TEST file=d:\daochu.dmp tables=(table1) query=\" where filed1 like '00%'\"

上面是常用的导出,对于压缩,既用winzip把dmp文件可以很好的压缩。
也可以在上面命令后面 加上 compress=y 来实现。

数据的导入
1 将D:\daochu.dmp 中的数据导入 TEST数据库中。
   imp system/manager@TEST file=d:\daochu.dmp
   imp aichannel/aichannel@HUST full=y file=file= d:\data\newsmgnt.dmp ignore=y 
   上面可能有点问题,因为有的表已经存在,然后它就报错,对该表就不进行导入。
   在后面加上 ignore=y 就可以了。
2 将d:\daochu.dmp中的表table1 导入
imp system/manager@TEST file=d:\daochu.dmp tables=(table1) 

基本上上面的导入导出够用了。不少情况要先是将表彻底删除,然后导入。

注意:
操作者要有足够的权限,权限不够它会提示。
数据库时可以连上的。可以用tnsping TEST 来获得数据库TEST能否连上。

附录一:
给用户增加导入数据权限的操作
第一,启动sql*puls
第二,以system/manager登陆
第三,create user 用户名 IDENTIFIED BY 密码 (如果已经创建过用户,这步可以省略)
第四,GRANT CREATE USER,DROP USER,ALTER USER ,CREATE ANY VIEW ,
   DROP ANY VIEW,EXP_FULL_DATABASE,IMP_FULL_DATABASE,
    DBA,CONNECT,RESOURCE,CREATE SESSION TO 用户名字 
第五, 运行-cmd-进入dmp文件所在的目录, 
    imp userid=system/manager full=y file=*.dmp
     或者 imp userid=system/manager full=y file=filename.dmp

执行示例:
F:\Work\Oracle_Data\backup>imp userid=test/test full=y file=inner_notify.dmp

屏幕显示
Import: Release 8.1.7.0.0 - Production on 星期四 2月 16 16:50:05 2006
(c) Copyright 2000 Oracle Corporation. All rights reserved.

连接到: Oracle8i Enterprise Edition Release 8.1.7.0.0 - Production
With the Partitioning option
JServer Release 8.1.7.0.0 - Production

经由常规路径导出由EXPORT:V08.01.07创建的文件
已经完成ZHS16GBK字符集和ZHS16GBK NCHAR 字符集中的导入
导出服务器使用UTF8 NCHAR 字符集 (可能的ncharset转换)
. 正在将AICHANNEL的对象导入到 AICHANNEL
. . 正在导入表                  "INNER_NOTIFY"          4行被导入
准备启用约束条件...
成功终止导入,但出现警告。


附录二:
Oracle 不允许直接改变表的拥有者, 利用Export/Import可以达到这一目的.
先建立import9.par,
然后,使用时命令如下:imp parfile=/filepath/import9.par
例 import9.par 内容如下:
        FROMUSER=TGPMS        
        TOUSER=TGPMS2     (注:把表的拥有者由FROMUSER改为TOUSER,FROMUSER和TOUSER的用户可以不同)           
        ROWS=Y
        INDEXES=Y
        GRANTS=Y
        CONSTRAINTS=Y
        BUFFER=409600
        file==/backup/ctgpc_20030623.dmp
        log==/backup/import_20030623.log

经验证,属合格产品!
posted @ 2011-09-26 14:27 kelly 阅读(367) | 评论 (0)编辑 收藏
为换成项目自带标志,我们仅仅需要修改一下项目根目录下的图标,有以下几个方法:
1、比如修改http://localhost:8080访问的图标,我们可以,修改E:\apache-tomcat-5.5.28\webapps\ROOT下的,ico文件,将该文件替换成想要的图标即可,命名也为favicon.ico,系统会自动找到这个文件。

2、系统部署到TOMCAT,访问时IE栏出现TOMCAT的小猫图标 

同样如果部署在webapps下面的也一样处理。
3、或者直接在tomcat安装跟目录下放一个命名为tomcat.ico文件的图标,所有项目将引用这个图标。(我暂时采用的这种方式)

 

但是,如果直接替换,效果不会显示出来,重启tomcat也不管用,这是由于浏览器缓冲造成的我们把历史记录删除即可。


posted @ 2011-06-24 10:46 kelly 阅读(1336) | 评论 (0)编辑 收藏

 

 

 

linux安装配置jdk1.5、tomcat5.5、eclipse3.2、Myeclipse

linux安装配置jdk1.5、tomcat5.5、eclipse3.2、Myeclipse5.1详解
      包括安装jdk1.5,tomcat5.5,eclipse3.2,Myeclipse5.1到配置搭建成功。

第一步:下载所须要的软件

下载jdk1.5。
下载tomcat5.5。
下载eclipse3.2。
下载Myeclipse5.1

第二步:安装已下载软件
假设你将上诉所要下载的软件全部从光盘拷贝或者通过pc机ftp到linux服务器上传到/home/user/Downloads目录下。

首先要安装jdk1.5
          1. 打开终端,运行命令su root 切换到超级用户。
          2.cd切换到/home/user/Downloads目录下。运行命令 cp jdk-1_5_0_12-linux-i586.bin /usr/local将jdk复制到/usr/local目录下。
          3.cd切换到/usr/local目录下。运行命令 chmod a+x jdk-1_5_0_12-linux-i586.bin给於相应权限。
          4.运行命令 ./jdk-1_5_0_12-linux-i586.bin 等待,按提示安装jdk,假设安装在/usr/local目录下。jdk安装完成。

然后安装tomcat5.5
              1.cd切换到/home/user/Downloads目录下。运行命令cp apache-tomcat-5.tar.gz /usr/local将其拷贝到/usr/local目录下。
          2.cd切换到/usr/local目录下。运行命令tar xvfz apache-tomcat-5.tar.gz将其在/usr/local目录中解压。tomcat5.5安装完成。

安装eclipse3.2
          1.cd切换到/home/user/Downloads目录下。运行命令cp eclipse-SDK-3.2.2-linux-gtk.tar.gz /usr/local将其拷贝到/usr/local目录下。
          2.cd切换到/usr/local目录下。运行命令tar xvfz eclipse-SDK-3.2.2-linux-gtk.tar.gz 将其解压。eclipse3.2安装完成。

安装Myeclipse5.1
1.cd切换到/home/user/Downloads目录下。运行命令cp MyEclipseEnterprise(Linux)WorkbenchInstaller_5_1_0GA_E3_2_1.bin /usr/local将其拷贝到/usr/local目录下。
          2.cd切换到/usr/local目录下。运行命令chmod +x MyEclipseEnterprise(Linux)WorkbenchInstaller_5_1_0GA_E3_2_1.bin ,然后运行$./M*.bin 安装过程中会提示选择Eclipse安装目录,按照你实际的Eclipse安装目录进行选择即可。Myeclipse安装完成。
到此步骤,安装软件已经完成了,但是还不能运行,还要进行配置。


第三步:配置环境变量

          首先运行命令 vi /etc/profile 出现profile文件源代码。
          按键盘子母“i”进入插入模式。
          在profile文件中插入以下代码:
           export JAVA_HOME=/usr/local/java
      export PATH=$JAVA_HOME/bin:$JAVA_HOME/jre/bin:$PATH
       export CLASSPATH=.:/usr/local/java/lib:/usr/local/java/jre/lib:$CLASSPATH
       export TOMCAT_HOME=/usr/local/tomcat
          我得源文件代码是这样:
# /etc/profile
# System wide environment and startup programs, for login setup
# Functions and aliases go in /etc/bashrc
pathmunge () {
        if ! echo $PATH | /bin/egrep -q "(^|:)$1($|:)" ; then
           if [ "$2" = "after" ] ; then
              PATH=$PATH:$1
           else
              PATH=$1:$PATH
           fi
        fi
}
# Path manipulation
#if [ `id -u` = 0 ]; then
        pathmunge /sbin
        pathmunge /usr/sbin
        pathmunge /usr/local/sbin
#fi
pathmunge /usr/X11R6/bin after
unset pathmunge
# No core files by default
ulimit -S -c 0 > /dev/null 2>&1

USER="`id -un`"
LOGNAME=$USER
MAIL="/var/spool/mail/$USER"

HOSTNAME=`/bin/hostname`
HISTSIZE=1000

if [ -z "$INPUTRC" -a ! -f "$HOME/.inputrc" ]; then
    INPUTRC=/etc/inputrc
fi

export JAVA_HOME=/usr/local/java
export PATH=$JAVA_HOME/bin:$JAVA_HOME/jre/bin:$PATH
export CLASSPATH=.:/usr/local/java/lib:/usr/local/java/jre/lib:$CLASSPATH
export TOMCAT_HOME=/usr/local/tomcat


export PATH USER LOGNAME MAIL HOSTNAME HISTSIZE INPUTRC

for i in /etc/profile.d/*.sh ; do
    if [ -r "$i" ]; then
        . $i
    fi
done
unset i
export G_BROKEN_FILENAMES=true
          黑体字部分是插入代码。
          插入完成后按“ESC”健。在按大写的子母“ZZ”。保存退出。
          环境变量配置完成后,可以做以下策试。
          运行命令java -version,出现jdk版本和相关信息,证明jdk已经OK了。
          cd切换到/opt/tomcat/bin目录下,运行命令 ./startup.sh,出现如下信息:
           Using CATALINA_BASE:   /opt/tomcat
           Using CATALINA_HOME:   /opt/tomcat
           Using CATALINA_TMPDIR: /opt/tomcat/temp
           Using JRE_HOME:       /usr/java/jre1.5.0_05
          证明安装成功。如果以上策试没成功的话,请仔细检查环境变量的配置。
          到此步骤为止,已经成功的配置完成了jdk和tomcat。该是配置我们eclipse的时候了。
posted @ 2011-03-03 17:18 kelly 阅读(6036) | 评论 (4)编辑 收藏

java处理日期时间 相加减
JAVA处理日期时间常用方法:

1.java.util.Calendar
Calendar 类是一个抽象类,它为特定瞬间与一组诸如 YEAR、MONTH、DAY_OF_MONTH、HOUR 等 日历字段之间的转换提供了一些方法,并为操作日历字段(例如获得下星期的日期)提供了一些方法。瞬间可用毫秒值来表示,它是距历元(即格林威治标准时间 1970 年 1 月 1 日的 00:00:00.000,格里高利历)的偏移量。

例:
Java代码 
1. Calendar cal = Calendar.getInstance();//使用默认时区和语言环境获得一个日历。   
2. cal.add(Calendar.DAY_OF_MONTH, -1);//取当前日期的前一天.   
3.  
4. cal.add(Calendar.DAY_OF_MONTH, +1);//取当前日期的后一天.   
5.  
6. //通过格式化输出日期   
7. java.text.SimpleDateFormat format = new java.text.SimpleDateFormat("yyyy-MM-dd");   
8.  
9. System.out.println("Today is:"+format.format(Calendar.getInstance().getTime()));   
10.  
11. System.out.println("yesterday is:"+format.format(cal.getTime())); 


得到2007-12-25日期:
Java代码 
1. Calendar calendar = new GregorianCalendar(2007, 11, 25,0,0,0);   
2. Date date = calendar.getTime();   
3. System.out.println("2007 Christmas is:"+format.format(date)); 

java月份是从0-11,月份设置时要减1.

GregorianCalendar构造方法参数依次为:年,月-1,日,时,分,秒.

取日期的部分:
Java代码 
1. int year =calendar.get(Calendar.YEAR);   
2.  
3. int month=calendar.get(Calendar.MONTH)+1;   
4.  
5. int day =calendar.get(Calendar.DAY_OF_MONTH);   
6.  
7. int hour =calendar.get(Calendar.HOUR_OF_DAY);   
8.  
9. int minute =calendar.get(Calendar.MINUTE);   
10.  
11. int seconds =calendar.get(Calendar.SECOND); 


取月份要加1.

判断当前月份的最大天数:
Java代码 
1. Calendar cal = Calendar.getInstance();   
2. int day=cal.getActualMaximum(Calendar.DAY_OF_MONTH);   
3. System.out.println(day); 


2.java.util.Date
Java代码 
1. java.util.Date today=new java.util.Date();   
2. System.out.println("Today is "+formats.format(today)); 


取当月的第一天:
Java代码 
1. java.text.SimpleDateFormat format = new java.text.SimpleDateFormat("yyyy-MM-01");   
2. java.util.Date firstDay=new java.util.Date();   
3. System.out.println("the month first day is "+formats.format(firstDay)); 

取当月的最后一天:
Java代码 
1.    
2. Calendar cal = Calendar.getInstance();   
3. int maxDay=cals.getActualMaximum(Calendar.DAY_OF_MONTH);   
4. java.text.Format formatter3=new java.text.SimpleDateFormat("yyyy-MM-"+maxDay);   
5. System.out.println(formatter3.format(cal.getTime())); 


求两个日期之间相隔的天数:
Java代码 
1. java.text.SimpleDateFormat format = new java.text.SimpleDateFormat("yyyy-MM-dd");   
2. java.util.Date beginDate= format.parse("2007-12-24");   
3. java.util.Date endDate= format.parse("2007-12-25");   
4. long day=(date.getTime()-mydate.getTime())/(24*60*60*1000);   
5. System.out.println("相隔的天数="+day); 

一年前的日期:
Java代码 
1. java.text.Format formatter=new java.text.SimpleDateFormat("yyyy-MM-dd");   
2. java.util.Date todayDate=new java.util.Date();   
3. long beforeTime=(todayDate.getTime()/1000)-60*60*24*365;   
4. todayDate.setTime(beforeTime*1000);   
5. String beforeDate=formatter.format(todayDate);   
6. System.out.println(beforeDate); 

一年后的日期:
Java代码 
1. java.text.Format formatter=new java.text.SimpleDateFormat("yyyy-MM-dd");   
2. java.util.Date todayDate=new java.util.Date();   
3. long afterTime=(todayDate.getTime()/1000)+60*60*24*365;   
4. todayDate.setTime(afterTime*1000);   
5. String afterDate=formatter.format(todayDate);   
6. System.out.println(afterDate); 

求10小时后的时间
Java代码 
1. java.util.Calendar Cal=java.util.Calendar.getInstance();   
2. Cal.setTime(dateOper);   
3. Cal.add(java.util.Calendar.HOUR_OF_DAY,10);   
4. System.out.println("date:"+forma.format(Cal.getTime())); 

求10小时前的时间
Java代码 
1. java.util.Calendar Cal=java.util.Calendar.getInstance();   
2. Cal.setTime(dateOper);   
3. Cal.add(java.util.Calendar.HOUR_OF_DAY,-10);   
4. System.out.println("date:"+forma.format(Cal.getTime())); 

3.java.sql.Date
继承自java.util.Date,是操作数据库用的日期类型
Java代码 
1. java.sql.Date sqlDate = new java.sql.Date(java.sql.Date.valueOf("2007-12-25").getTime()); 

日期比较:简单的比较可以以字符串的形式直接比较,也可使用
java.sql.Date.valueOf("2007-03-08").compareTo(java.sql.Date.valueOf("2007-03-18"))方式来比较日期的大小.也可使用java.util.Date.after(java.util.Date)来比较.

相差时间:
long difference=c2.getTimeInMillis()-c1.getTimeInMillis();
相差天数:long day=difference/(3600*24*1000)
相差小时:long hour=difference/(3600*1000)
相差分钟:long minute=difference/(60*1000)
相差秒: long second=difference/1000

补充:
Java代码 
1. DateFormat df=new SimpleDateFormat("yyyy-MM-dd EE hh:mm:ss");   
2. System.out.println(df.format(new Date()));   
3. Date date = new Date();   
4. DateFormat shortDate=DateFormat.getDateTimeInstance(DateFormat.SHORT, DateFormat.SHORT);   
5. DateFormat mediumDate =DateFormat.getDateTimeInstance(DateFormat.MEDIUM, DateFormat.MEDIUM);   
6. DateFormat longDate =DateFormat.getDateTimeInstance(DateFormat.LONG, DateFormat.LONG);   
7. DateFormat fullDate =DateFormat.getDateTimeInstance(DateFormat.FULL, DateFormat.FULL);   
8.  
9. system.out.println(shortDate.format(date));   
10. System.out.println(mediumDate.format(date));   
11. System.out.println(longDate.format(date));   
12. System.out.println(fullDate.format(date));   
13.  
14. 08-4-15 下午3:24   
15. 2008-4-15 15:24:31   
16. 2008年4月15日 下午03时24分31秒   
17. 2008年4月15日 星期二 下午03时24分31秒CST   
18.  
19.  
20. Calendar c = Calendar.getInstance();   
21.  
22. c.add(Calendar.MONTH, 1); // 目前時間加1個月   
23. System.out.println(df.format(c.getTime()));   
24.  
25. c.add(Calendar.HOUR, 3); // 目前時間加3小時   
26. System.out.println(df.format(c.getTime()));   
27.  
28. c.add(Calendar.YEAR, -2); // 目前時間減2年   
29. System.out.println(df.format(c.getTime()));   
30.  
31. c.add(Calendar.DAY_OF_WEEK, 7); // 目前的時間加7天   
32. System.out.println(df.format(c.getTime()));

posted @ 2011-02-21 12:15 kelly 阅读(28806) | 评论 (0)编辑 收藏
仅列出标题
共15页: First 上一页 5 6 7 8 9 10 11 12 13 下一页 Last