Dust Of Dream

知识真的是一个圆么?

#

Ruby学习笔记二:使用Ruby实现通过Proxy的方式请求网页

现在很多网站上某些活动都有限制同一IP只能投一票的规定,但是有时候迫于压迫,又不得不想办法多投几票,以前是采用Apache里的HttpClient来实现这些功能,日前正在看Ruby,就用它也来玩下:
require 'net/http'
##获得网页内容
def query_url(url)
return Net::HTTP.get(URI.parse(url));
end

#抓取cnproxy上所有的代理列表,并将结果保存到proxy.txt中去
#你可以修改这块代码或者其他的代理服务器列表

def find_all_proxy
z
="3";j="4";r="2";l="9";c="0";x="5";i="7";a="6";p="8";s="1"
pf
= File.new("proxy.txt","w+")
for page_no in 1..10
url
= "http://www.cnproxy.com/proxy#{page_no}.html"
content
= query_url(url)
#print content
## ^$?./\[]{}()+*

for array in content.scan(/<td>(.*?)<SCRIPT type=text\/javascript>document.write\(":"\+(.*?)\)<\/SCRIPT><\/td>/)
if array.length == 2
pf
.write("#{array[0]}:#{eval(array[1])}\n")
end
end
end
pf
.close
end

##处理请求
def open_url_with_proxy(url)
pf
= File.open("proxy.txt","r")
d
= []
pf
.each { |line| d << line }
for var in d
print "User Proxy #{var}\n"
begin
proxy
= Net::HTTP::Proxy(var.split(":")[0],var.split(":")[1].to_i)
print proxy.get(URI.parse(url));
#print proxy.start("www.google.com",80){|http|
# response = http.get('/index.html')
# puts response.body
#}

rescue
##吃掉异常
end
end
end

##主程序
begin
if !FileTest.exist?( "proxy.txt" )
find_all_proxy
end
open_url_with_proxy(
'http://www.google.com/index.html');
end
这里需要注意的是代理服务器的端口不能是String类型,Ruby竟然不会自动转换,搞得我浪费了N多时间.

posted @ 2008-10-17 17:27 Anemone 阅读(1359) | 评论 (1)编辑 收藏

Ruby学习笔记一:安装Ruby与Ruby的爬虫应用

最近终于空下来了,所以下个Ruby玩玩,安装Ruby很简单,去官网下载一个一键安装包既可,linux下的安装,大家Google下就有很多教程了.对于IDE网上说NetBeans支持得很完美,但是因为本人比较喜欢Eclipse,所以还是跟大家推荐EasyEclipse for Ruby and Rails,当然你可以选择只下RoR的插件而不弄个全新的Eclipse.
以前一直在用Java写爬虫工具抓图片,对HttpClient包装,正则表达式处理那个是累啊,就算弄好了工具类,有时候一会又想不起来放哪儿,但Ruby对方面包装的就很强大,短短几十行代码就搞定了这一切:
页面获取和文件下载的方法.
util.rb:

require 'net/http'
def query_url(url)
  
return Net::HTTP.get(URI.parse(url));
end

def save_url(url
,dir,filename)
  filename 
= url[url.rindex('/')+1, url.length-1if filename == nil || filename.empty?
  
require 'open-uri'
  Dir
.mkdir("#{dir}"if dir != nil && !dir.empty? && !FileTest.exist?(dir)
  
open(url) do |fin|
    
if true
    File
.new("#{dir}#{filename}","wb").close
    
open("#{dir}#{filename}","wb"do |fout|
      
while buf = fin.read(1024do
        fout
.write buf
        STDOUT
.flush
      end
    end
    end
  end
end

抓取图片的具体应用:
require "util"
begin
  start_url 
= 'http://list.mall.taobao.com/1424/g-d-----40-0--1424.htm'
  
while start_url != nil && !start_url.empty? do
    
print "开始下载#{start_url}\n"
    content 
= query_url(start_url)
    next_page 
= content.scan(/ <a href="(.*?)" class="next-page"><span>下一页<\/span><\/a>/)
    next_url 
= nil
    next_url 
= next_page[0][0if  next_page != nil && next_page.length > 0 && next_page[0].length > 0

    imgs 
= content.scan(/<img src="(http:\/\/img[\d].*?)" \/>/)
    
for img in imgs
      url 
= img[0];
      save_url(url
,"d:\\mall\\",nil)
    end

    start_url 
= next_url;
    
#    break;
  end

end
使用一天之后感觉ruby的语法很自然,很好理解,上手比较容易,而且相关包封装的也很好,确实比较适合拿来玩玩小程序.

posted @ 2008-10-15 10:11 Anemone 阅读(1994) | 评论 (0)编辑 收藏

使用Javascript让某个HTML区块的链接失效

在开发中时常会遇到这样的需求:让某些描述信息(这些描述信息已经进行过安全html过滤,所以不会包含Javascript等脚本语言,但是允许正常的链接)里的链接失效,但是不要或者这些描述信息.如要以下代码块里的链接失效

<div id="desc">
   
<href="http://www.9i56.cn">无聊网</a>
</div>

只需要再后面插入下段Javascript既可
<script type="text/javascript">
    
var elements = document.getElementById('desc').getElementsByTagName('A');
    
for (var i = 0, len = elements.length; i < len; ++i) {
        elements[i].onclick 
= function(){return false;};
        elements[i].href 
= "#";
    }
    
var elementsArea = document.getElementById('desc').getElementsByTagName('area');
    
for (var i = 0, len = elementsArea.length; i < len; ++i) {
        elementsArea[i].onclick 
= function(){return false;};
        elementsArea[i].href 
= "#";
    }
</script>
目前只知道a和area标签可以放href属性来进行跳转,不知道大家还知道有其它的方式可以用href跳转吗?

posted @ 2008-10-15 09:51 Anemone 阅读(2303) | 评论 (2)编辑 收藏

JMail 简单应用-文件传输

    日常工作中,常常要将在公司做的东西拷回家,或者要从家里拷东西到公司,但是如果用U盘拷又太麻烦,上web发邮件又有点烦,所以就做了下面的小程序,发送前切版里的内容到指定邮箱来传递文件.
    相关技术点:
    1.JMail邮件发送
    2.剪切板提取
   具体代码实现如下:
/*
 * Created on 2008-3-5
 
*/
package org.dueam.ft;

import java.awt.HeadlessException;
import java.awt.Toolkit;
import java.awt.datatransfer.DataFlavor;
import java.awt.datatransfer.UnsupportedFlavorException;
import java.io.File;
import java.io.IOException;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.List;

import org.apache.commons.mail.EmailAttachment;
import org.apache.commons.mail.EmailException;
import org.apache.commons.mail.MultiPartEmail;

import sun.misc.BASE64Encoder;

/**
 * 剪切板内容发生
 * 
@author <a href="mailto:windonly@gmail.com">Anemone</a>
 * hz,zj,china(2008-3-5)
 
*/
public class ClipboardFileTransmission {

    
/**
     * 
@param args
     * 
@throws EmailException
     * 
@throws IOException
     * 
@throws UnsupportedFlavorException
     * 
@throws HeadlessException
     
*/
    @SuppressWarnings(
"unchecked")
    
public static void main(String[] args) throws EmailException, HeadlessException, UnsupportedFlavorException,
            IOException {
        String context 
= null;
        List
<File> fileList = null;
        
/**
         * 处理前切版
         
*/
        
for (DataFlavor df : Toolkit.getDefaultToolkit().getSystemClipboard().getAvailableDataFlavors()) {
            
//如果拷贝的是文本内容
            if (df.equals(DataFlavor.stringFlavor)) {
                context 
= (String) Toolkit.getDefaultToolkit().getSystemClipboard().getData(DataFlavor.stringFlavor);
            }
            
else if (df.equals(DataFlavor.javaFileListFlavor)) {
                
//如果拷贝的是文件则当附件发送
                fileList = (List<File>) Toolkit.getDefaultToolkit().getSystemClipboard().getData(
                        DataFlavor.javaFileListFlavor);
            }
        }
        
if ((null == context || "".equals(context)) && (fileList == null || fileList.isEmpty())) {
            
return;
        }
        
if (null == context || "".equals(context)) {
            context 
= "具体资料请看附件";
        }

        MultiPartEmail email 
= new MultiPartEmail();
        
        
// 发送服务器
        email.setHostName("smtp.163.com");
        
//服务器用户和密码(如果你自己搞了台不用验证的邮件服务器就不用了)
        email.setAuthentication("XXX""XXX");
        
//接收的邮箱
        email.addTo("XXX@gmail.com""我的资料库");
        
//发送服务器的邮件地址,现在很多邮件提供商都有验证这个同用户名是否对应,还是老老实实填真实的吧
        email.setFrom("XXX@163.com""Anemone");
        email.setSubject(
"[日常资料传递]-" + getTime());
        
//文本编码
        email.setCharset("utf-8");
        email.setMsg(context);
        
if (null != fileList)
            
for (File f : fileList) {
                
if (f.exists() && f.isFile()) {
                    
//处理附件
                    EmailAttachment attachment = new EmailAttachment();
                    attachment.setPath(f.getPath());
                    attachment.setDisposition(EmailAttachment.ATTACHMENT);
                    attachment.setDescription(getTime() 
+ "By Anemone");
                    BASE64Encoder enc 
= new BASE64Encoder();
                    
//附件中文名问题
                    attachment.setName("=?GBK?B?" + enc.encode(f.getName().getBytes()) + "?=");
                    email.attach(attachment);
                }
            }

        email.send();

    }

    
public static String getTime() {
        SimpleDateFormat df 
= new SimpleDateFormat("yyyy-MM-dd HH:mm");
        
return df.format(new Date());
    }

}
以上代码在163和gmail之间测试通过过,建议用exe4j打成EXE文件,然后扔到system32目录下面,这样只要想发送资料的时候,只要复制下资料,再执行下这个命令就一切都OK了.
相关类包:下载


posted @ 2008-03-19 10:03 Anemone 阅读(1591) | 评论 (5)编辑 收藏

ArrayUtils学习笔记

ArrayUtils 拥有以下方法:
toString
将一个数组转换成String,用于打印数组
isEquals
判断两个数组是否相等,采用EqualsBuilder进行判断
toMap
将一个数组转换成Map,如果数组里是Entry则其Key与Value就是新Map的Key和Value,如果是Object[]则Object[0]为KeyObject[1]为Value
clone
拷贝数组
subarray
截取子数组
isSameLength
判断两个数组长度是否相等
getLength
获得数组的长度
isSameType
判段两个数组的类型是否相同
reverse
数组反转
indexOf
查询某个Object在数组中的位置,可以指定起始搜索位置
lastIndexOf
反向查询某个Object在数组中的位置,可以指定起始搜索位置
contains
查询某个Object是否在数组中
toObject
将基本数据类型转换成外包型数据
isEmpty
判断数组是否为空(null和length=0的时候都为空)
addAll
合并两个数组
add
添加一个数据到数组
remove
删除数组中某个位置上的数据
removeElement
删除数组中某个对象(从正序开始搜索,删除第一个)
eg:
        // 1.打印数组
        ArrayUtils.toString(new int[] { 1423 });// {1,4,2,3}
        ArrayUtils.toString(new Integer[] { 1423 });// {1,4,2,3}
        ArrayUtils.toString(null"I'm nothing!");// I'm nothing!

        
// 2.判断两个数组是否相等,采用EqualsBuilder进行判断
        
// 只有当两个数组的数据类型,长度,数值顺序都相同的时候,该方法才会返回True
        
// 2.1 两个数组完全相同
        ArrayUtils.isEquals(new int[] { 123 }, new int[] { 123 });// true
        
// 2.2 数据类型以及长度相同,但各个Index上的数据不是一一对应
        ArrayUtils.isEquals(new int[] { 132 }, new int[] { 123 });// true
        
// 2.3 数组的长度不一致
        ArrayUtils.isEquals(new int[] { 1233 }, new int[] { 123 });// false
        
// 2.4 不同的数据类型
        ArrayUtils.isEquals(new int[] { 123 }, new long[] { 123 });// false
        ArrayUtils.isEquals(new Object[] { 123 }, new Object[] { 1, (long23 });// false
        
// 2.5 Null处理,如果输入的两个数组都为null时候则返回true
        ArrayUtils.isEquals(new int[] { 123 }, null);// false
        ArrayUtils.isEquals(nullnull);// true

        
// 3.将一个数组转换成Map
        
// 如果数组里是Entry则其Key与Value就是新Map的Key和Value,如果是Object[]则Object[0]为KeyObject[1]为Value
        
// 对于Object[]数组里的元素必须是instanceof Object[]或者Entry,即不支持基本数据类型数组
        
// 如:ArrayUtils.toMap(new Object[]{new int[]{1,2},new int[]{3,4}})会出异常
        ArrayUtils.toMap(new Object[] { new Object[] { 12 }, new Object[] { 34 } });// {1=2,
        
// 3=4}
        ArrayUtils.toMap(new Integer[][] { new Integer[] { 12 }, new Integer[] { 34 } });// {1=2,
        
// 3=4}

        
// 4.拷贝数组
        ArrayUtils.clone(new int[] { 324 });// {3,2,4}

        
// 5.截取数组
        ArrayUtils.subarray(new int[] { 34156 }, 24);// {1,5}
        
// 起始index为2(即第三个数据)结束index为4的数组
        ArrayUtils.subarray(new int[] { 34156 }, 210);// {1,5,6}
        
// 如果endIndex大于数组的长度,则取beginIndex之后的所有数据

        
// 6.判断两个数组的长度是否相等
        ArrayUtils.isSameLength(new Integer[] { 135 }, new Long[] { 2L8L10L });// true

        
// 7.获得数组的长度
        ArrayUtils.getLength(new long[] { 1233 });// 3

        
// 8.判段两个数组的类型是否相同
        ArrayUtils.isSameType(new long[] { 13 }, new long[] { 856 });// true
        ArrayUtils.isSameType(new int[] { 13 }, new long[] { 856 });// false

        
// 9.数组反转
        int[] array = new int[] { 125 };
        ArrayUtils.reverse(array);
// {5,2,1}

        
// 10.查询某个Object在数组中的位置,可以指定起始搜索位置,找不到返回-1
        
// 10.1 从正序开始搜索,搜到就返回当前的index否则返回-1
        ArrayUtils.indexOf(new int[] { 136 }, 6);// 2
        ArrayUtils.indexOf(new int[] { 136 }, 2);// -1
        
// 10.2 从逆序开始搜索,搜到就返回当前的index否则返回-1
        ArrayUtils.lastIndexOf(new int[] { 136 }, 6);// 2

        
// 11.查询某个Object是否在数组中
        ArrayUtils.contains(new int[] { 312 }, 1);// true
        
// 对于Object数据是调用该Object.equals方法进行判断
        ArrayUtils.contains(new Object[] { 312 }, 1L);// false

        
// 12.基本数据类型数组与外包型数据类型数组互转
        ArrayUtils.toObject(new int[] { 12 });// new Integer[]{Integer,Integer}
        ArrayUtils.toPrimitive(new Integer[] { new Integer(1), new Integer(2) });// new int[]{1,2}

        
// 13.判断数组是否为空(null和length=0的时候都为空)
        ArrayUtils.isEmpty(new int[0]);// true
        ArrayUtils.isEmpty(new Object[] { null });// false

        
// 14.合并两个数组
        ArrayUtils.addAll(new int[] { 135 }, new int[] { 24 });// {1,3,5,2,4}

        
// 15.添加一个数据到数组
        ArrayUtils.add(new int[] { 135 }, 4);// {1,3,5,4}

        
// 16.删除数组中某个位置上的数据
        ArrayUtils.remove(new int[] { 135 }, 1);// {1,5}

        
// 17.删除数组中某个对象(从正序开始搜索,删除第一个)
        ArrayUtils.removeElement(new int[] { 135 }, 3);// {1,5}

posted @ 2008-02-26 18:23 Anemone 阅读(11067) | 评论 (6)编辑 收藏

罗莎来了

来杭州这么久从来没见过这么厉害的台风,竟然可以把杭城改造成半个威尼斯.不知道为什么雨天总是给人压抑的感觉,虽然自认为很喜欢雨天,但是却无法将扑灭心中沮丧的心情,很想一笑而过,可惜往往无功而返.有时候很想问问自己,你真的了解镜子里那个人么?或者说你想去了解吗?

posted @ 2007-10-08 21:34 Anemone 阅读(219) | 评论 (1)编辑 收藏

发帖机的应对策略

现在网络上发帖机横行,如何在尽可能少地影响用户体验的同时阻止发帖机是每个网站面临的课题.
一 常见发帖机类型及其原理
1)程序自动构建字段内容,然后通过程序自动POST到服务器.
2)通过按键精灵之类的模拟器模拟键盘和鼠标操作,以达到自动发帖的目的.
二 发帖机行为分析
发帖机主要是为了发布广告信息,所以一般发帖机都是采用即时创建帐号==>然后发帖==>然后闪人流程散布信息.
三 解决方案
1)通过增加一个特殊字段,系统可以通过验证这个特殊字段来确认当前信息是否是系统实时产生.这种方法可以有效抑制通过程序自动POST数据的发帖机,但是无法阻止模拟器类型的发帖机.
2)验证码.验证码是最有效的阻止发帖机的手段,但验证码也影响了用户的发帖体验,根据发帖机的行为分析我们可以采用如果当前用户注册还未满一个月或者发帖数还未达到10之前必需输入验证码,这样既不影响老用户的发帖体验又可以达到抑制发帖机的作用.
四 特殊字段产生策略
可以采用时间戳+时间戳加密(加密方案参见我的另一篇文章),然后在服务器验证当前客户端传上来的时间戳是否在允许的timeout之内.

posted @ 2007-10-01 20:58 Anemone 阅读(962) | 评论 (0)编辑 收藏

Oracle SQL培训笔记[开发人员][三]

四 索引与分页--怎么样SQL运行的更快

  1. 正确的使用索引
    Where条件落在索引上
    不要在where的=前使用函数,否则无法使用索引
    Is Null可能无法使用索引
    不正确的隐式转换可能不能使用索引
    如果能在索引获得数据,就不要回表
    如果是复合索引,注意第2个字段以后,可能使用不到索引
  2. 正确的使用hint
    如果有别名,一定要有别名
    格式如/*+ index(t index_name) */
  3. 无需回表查询的分页写法
    存在以下表T1(A,B,C,D) T1上有索引字段(B,C) .如果只是查B,C两个字段则:
    select *
      
    from (select tt.b, tt.c, rownum as rn
              
    from (select t.b, t.c from t1 t where c = 2 order by t.c) tt
             
    where rownum < 3)
     
    where rn > 1
  4. 需回表查询的分页写法
    select /*+ ordered use_nl(t,t1) */ 
          
    * 
           
    from (select rid from (
              
    select rownum rn,rid from (
                
    select rowid rid from t1
                 
    where c=2 
                 
    order by c desc
              
    where rownum <= 50
           
    where rn >=1) t,
           t1
    where t.rid=t1.rowid;


posted @ 2007-10-01 12:48 Anemone 阅读(947) | 评论 (1)编辑 收藏

Oracle SQL培训笔记[开发人员][二]

三 null的那些事

  1. 在order 中,简单把null认为是最大
  2. 与null的运算,返回null
    SQL> select 1 + null from dual;

        
    1+NULL
    ----------
  3. 与null的字符串合并,忽略null
    SQL> select 'Hi'||null from dual;

    'HI'||NULL
    ----------
    Hi
  4. Null的查询为is null
  5. Count(field),不包括null
  6. 如果索引条目全为null,则索引不记录null
  7. In/not in与null
  8. Exists/not exists与null
    SQL> select * from t1;

    A          B
    ---------- ----------
    1          1
    2          
    3          

    SQL
    > select * from t2;

    A          B
    ---------- ----------
    1          1
    2          

    SQL
    > select * from t1 where b in (select B from t2);

    A          B
    ---------- ----------
    1          1

    SQL
    > select * from t1 where b not in (select B from t2);

    A          B
    ---------- ----------

    SQL
    > select * from t1 where exists (select * from t2 where t2.b = t1.b);

    A          B
    ---------- ----------
    1          1

    SQL
    > select * from t1 where not exists (select * from t2 where t2.b = t1.b);

    A          B
    ---------- ----------
    3          
    2          

    exists主要用于片面的,有满足一个条件的即可,  所以速度快很多.    in   主要用于具体的集合操作,   有多少满足条件.

posted @ 2007-10-01 12:25 Anemone 阅读(929) | 评论 (0)编辑 收藏

Oracle SQL培训笔记[开发人员][一]

近日公司的Oracle牛人给我们开发人员做了一次有关Oracle的培训,感觉收获颇大,故记录下来,好他日温习之用.

一 常用的SQL语句

  1. select name,count(*) from table where .. group by ... 中能查询的字段只能为group by的字段.

  2. select * from table where rownum < 5 order by id 中查询出来的结果不是按数据中的ID排序的,而只是将select * from table where rownum < 5 的结果集按ID排序,所以如果你要按ID排序,你需要用子查询实现:
    select * from ( select * from table order by id ) where rownum < 5 
  3. select * from table where name like 'A\_%' escape '\';将'\'后面的字符不当关键字来处理,这个字符可以自定义.

  4. insert into test(id,name) values(9,'It''s life'); or ||chr(39)|| 如果你想插入'可以使用''或者||chr(39)||方式插入.

  5. 如果你想将T1中B更新为T2中的B值,千万要注意限定T1的范围,否则T1的全部列将会更新,如update t1 t set t.B = (select tt.B from t2 tt where tt.A = t.A)将会t1中所有列都更新,如果t2中不存在对应值,则t1中的值则为NULL,所以应该将以上语句改造成update t1 t set t.B = (select tt.B from t2 tt where tt.A = t.A) where t.A in (select A from t2)

  6. number(5,2):如果用 insert into test values(123.235)进行插入时,将会使用四舍五入的方式插入即值为123.24;如果是insert into test values(12345)则无法插入数据

二 Oracle 函数

  1. 一般函数是数据库设定的字符集来计算,现在一般的oracle都是16位,所以一个汉字长度为1,而函数后面加b则按字节来计算如:length('中国')=2 lenghtb('中国')=4 .
  2. Substr与substrb 字符串截取函数,负数代表从右开始截取
    SQL> select substr('我是中国人',2from dual;

    SUBSTR(
    '我是中国人',2)
    ----------------------
    是中国人

    SQL
    > select substrb('我是中国人',2from dual;

    SUBSTRB(
    '我是中国人',2)
    -----------------------
     是中国人

    SQL
    > select substr('我是中国人',-2from dual;

    SUBSTR(
    '我是中国人',-2)
    -----------------------
    国人

    SQL
    > select substrb('我是中国人',-2from dual;

    SUBSTRB(
    '我是中国人',-2)
    ------------------------

    Length与lengthb 长度计算函数
    SQL> select length('我是中国人'from dual;

    LENGTH(
    '我是中国人')
    --------------------
                       5

    SQL
    > select lengthb('我是中国人'from dual;

    LENGTHB(
    '我是中国人')
    ---------------------
                       10
    Instr与Instrb 字符串查找函数 instr(原字符串,查的字符串,起始位置,第几个匹配) 返回字符串位置,找不到返回0 .
    SQL> select Instr('abcabcdabcdef','a',1,3from dual;

    INSTR(
    'ABCABCDABCDEF','A',1,3)
    ------------------------------
                                 8

    Upper与lower 大小写转换函数
    SQL> select upper('AaBbCc'from dual;

    UPPER('AABBCC')
    ---------------
    AABBCC

    SQL
    > select lower('AaBbCc'from dual;

    LOWER('AABBCC')
    ---------------
    aabbcc

    Trim/Rtrim/Ltrim 字符串trim函数
    SQL> select trim(' A B 'from dual;

    TRIM(
    'AB')
    ----------
    A B

    SQL
    > select rtrim('xABx','x'from dual;

    RTRIM('XABX','X')
    -----------------
    xAB

    SQL
    > select ltrim('xABx','x'from dual;

    LTRIM('XABX','X')
    -----------------
    ABx

    Trunc 截取函数(不进行四舍五入)
    SQL> select trunc(1234.123456,'-2'from dual;

    TRUNC(
    1234.123456,'-2')
    -----------------------
                       1200

    SQL
    > select trunc(1234.123456,'2'from dual;

    TRUNC(
    1234.123456,'2')
    ----------------------
                   1234.12

    SQL
    > select trunc(1234.123456,'4'from dual;

    TRUNC(
    1234.123456,'4')
    ----------------------
                 1234.1234

    SQL
    > select trunc(1234.123456,'5'from dual;

    TRUNC(
    1234.123456,'5')
    ----------------------
                1234.12345

    SQL
    > select trunc(sysdate,'yy'from dual;

    TRUNC(SYSDATE,
    'YY')
    -------------------
    2007-01-01

    SQL
    > select trunc(sysdate,'mi'from dual;

    TRUNC(SYSDATE,
    'MI')
    -------------------
    2007-10-01 11:55:00

    SQL
    > select trunc(sysdate,'dd'from dual;

    TRUNC(SYSDATE,
    'DD')
    -------------------
    2007-10-01

    SQL
    > select trunc(sysdate,'day'from dual;

    TRUNC(SYSDATE,
    'DAY')
    --------------------
    2007-09-30
    Next_day与last_day
    SQL> select sysdate from dual;

    SYSDATE
    -----------
    2007-10-01

    SQL
    > select next_day(sysdate,'星期一'from dual;

    NEXT_DAY(SYSDATE,
    '星期一')
    --------------------------
    2007-10-08 11:57:29

    SQL
    > select next_day(sysdate,1from dual;

    NEXT_DAY(SYSDATE,
    1)
    -------------------
    2007-10-07 11:57:42

    SQL
    > select next_day(sysdate,2from dual;

    NEXT_DAY(SYSDATE,
    2)
    -------------------
    2007-10-08 11:57:56
    SQL> select last_day(sysdate) from dual;

    LAST_DAY(SYSDATE)
    -----------------
    2007-10-31 12:00:
    Round 四舍五入函数
    SQL> select round(123.456,2from dual;

    ROUND(123.456,2)
    ----------------
              123.46

    SQL
    > select round(123.456,-2from dual;

    ROUND(123.456,-2)
    -----------------
                  100

    SQL
    > select round(123.456,-1from dual;

    ROUND(123.456,-1)
    -----------------
                  120

    Ceil与floor 取整函数
    SQL> select ceil(1.1from dual;

     CEIL(
    1.1)
    ----------
             2

    SQL
    > select floor(9.9from dual;

    FLOOR(9.9)
    ----------
             9
    Decode与nvl Decode相当于一个三元运算函数 nvl 如果值为空时默认值.

posted @ 2007-10-01 12:09 Anemone 阅读(1393) | 评论 (0)编辑 收藏

仅列出标题
共3页: 上一页 1 2 3 下一页 

My Links

Blog Stats

News

常用链接

留言簿(1)

随笔分类

随笔档案

新闻档案

相册

常去网站

搜索

积分与排名

最新评论

阅读排行榜

评论排行榜