我在北大青鸟学习的时候随便整理的资料 SQL SERVER 2005

--基础:

select * from area 
select * from cgfpmxb


/*可以包含任意表达式*/
/*指定别名可以直接写 也可以 as aa   */
/*将两个字段合并成一个字段的方法 用||*/
/*可以在语句中加一个字符串 用单引号括起来*/
select itemid || itemname || amount || 'hello'
taxamount,amount*taxratio/10.00 "aa"

 from  cgfpmxb
 
 
 /*null的使用*/ 
 select * from djzhb
where ca is not null
/*在计算表达式的时候 只要表达式中有null 整个结果都是NULL*/
select amount , amount+null from cgfpmxb
/*为防止表达式因出现空值而 影响运算 可以为空值指定一个值,
当在计算表达式的时候,如果遇到空值,就会用指定的数值替代*/
select amount,amount+nvl(null,0) from cgfpmxb



/*nvl在日期中的处理,很重要*/
/*如何将字符日期,转换成日期格式*/
select nvl(checkdate, to_date('1900-01-01','yyyy-mm-dd')) 
from djzhb 
where(ca is null)


/*获取系统时间函数*/
select sysdate 


--可以将查询结果重复记录消灭掉,只要我们选取的两列相同,就被视作重复
select  distinct distcode ,distname from djzhb



/*获取前两行数据*/
/*rownum式系统函数,可以为表产生一个id列,从而在where中指定id来判断行数*/
select * from
       (select rownum id, djzhb. * from djzhb) 
        where id<3

 
 
 /*排序*/
/* 升序:asc  降序:desc*/
/*可以在排序指定别名*/
 select distcode code,distname from djzhb
 order by distcode  asc
 
 
  select distcode code,distname ,ca from djzhb
 order by ca  desc
 
 /*可以指定多列来排序,*/
/* distinct可以去掉重复,你选几列就按照几列来判断是否相同,只有选出的列的字段值都相同才被视为相同*/
  select distinct distcode code,distname ,ca from djzhb
 order by distcode,distname   desc
 
-- 一般对一列使用distinct,,在MSSQL中直接就会按照一列进行排序
 select distinct distcode from djzhb 
 order by distcode
 
 
 
 
 /*where用法*/
 
 select distinct distcode,distname,ordertype 
 from djzhb
 where distcode='63345'
 
 /*where处理日期*/
 select  distcode , distname,ordertype, uploaddate
 from djzhb 
 where uplorddate= to_date('2006-09-25','yyyy-mm-dd')
 
/* where可以使用<> <= >= 等符号*/
 select * from area 
 where di >=4
 
/* 可以使用between和in*/
 select  * from area
 where id between 1 and 4
 
/* 离散的数字 和SQL一样*/
 select * from area 
 where id in (1,4,5)
 
 
 /*模糊查询*/
-- %表示任意字符
 select * from province
 where name_c like '%海' /*表示查找最后一个字式海的 */
 
/* _表示单个字符*/
 select * from province 
 where name_c like '北_'

/* 转意字符,必须自己定义
 如果字段中含有 %这个符号 ,要寻找 含有这个符号的那行,就必须使用转意符号,*/
 select * from area 
 where name_en like '%\%' escape '\' 
 
 /*可以指定任意的转义符号*/
 select * from area 
 where name_en like '%+%' escape '+'/* 指定 +为转意符号,表示查询以%结束的字段 */
 
-- 可以使用 and 或 or 来 连接 多个查询条件
  select * from area 
 where id< 4 or name_cn like '%华'
 
 
 
 
 
 
 
 
 
 /*函数*/
/* 1*/
 /*字符串函数:*/
-- lower 
-- upper
-- initcap
-- concat
-- substr
-- length
-- nvl
 
 /*转换成
 小写
 大写
 substr取出某字段值,从第一个字符开始,连续取出10个字符
 取出字符串的长度
 判断其是否包含GUIDE 如果包含就返回第一次找到的在字段中的起始位置
 将两个字符串合并成一个新的字符串*/
 select item_number,
        lower(name_e),
        initcap(name_e),
        substr(name_e,1,5),
        length(name_e),
        instr(name_e,'GUIDE')
        concat(name_e,name_c)
 from item_master_tb
 
 /*
 
 
 
 2*/
 /*数值型函数
 round  小数点后取两位,最后一位根据四舍五入来确定大小(如果式负数 会影响到整数部分)
 trunc   取小数点后指定的位数,把小数点后面的直接截掉,不会四舍五入*/
 
 /*dual 是假表*/
 select  round(43.345,2), 
         round(43.345,1), 
         round(43.345,-1),
         trunc(45.546,2),
         trunc(45.3455,-1)
 from dual 
 
 
 
/*3*/
/* 时间函数
 sysdate获取系统时间*/
 select sysdate from dual 
 select sysdate+600 from dual /*默认加的式天数*/
 
 
/* 连个时间的相减 
 表示加六个月
 获取下个星期的第一天式几号
 当前月的最后一天,很重要,可以在编程的时候用到
 按照月份四舍五入  只显示到月份
 按照天 四舍五入   只显示到天 时间就被舍弃了
 按照年 四舍五入   只显示年
 year表示对年四舍五入
 dd表示明天*/
 select months_between( to_date('2010-01-01','yyyy-mm-dd'),sysdate),
 add_months(sysdate,6),
 next_day(sysdate,1),
 last_day(sysdate),
 last_day(to_date('2008-02-11','yyyy-mm-dd')),
 round(sysdate,'MONTH'),
 round(sysdate,'day'),
 round(sysdate,'year'),
 round(sysdate,'dd'),
 from dual 
 
 
/* 4
 时间的转换
 YYYY年               英文表示
 YEAR                 数字表示
 MM 月                英文表示
 MONTH月              英文
 DY星期 中文
 DD星期 英文
 DAY日期 
 MI 分钟 
 SS 秒 
 HH24 24小时时间表示  
 HH默认的小时表示*/
 
 select to_char(sysdate,'YEAR-MONTH-DAY'),
        tO_char(sysdate,'YEAR-MONTH-DY'),
        tO_char(sysdate,'YEAR-MONTH-ddspth'),
        to_char(sysdate,'yyyy-mm-dd HH24:MI:SS')
      
 from dual
 
 
 
 
/* 
 5
 将数字转换成字符串
 第二个参数  转换的格式
 9表示0-9的任意一个数字,超过就无法显示, 
  0表示占位,如果不够用0补齐
 1显示1234
 2第二个数字的位数超过格式规定的位数,所以无法显示
 3少于规定的格式两个 ,所以只显示12
 4 0表示占位
 5 转换小数,要在小数点前后定义格式
 6 L表示转换成 人民币
   $表示美元
 */

 
 select  to_char(1234,'9999'),
         to_char(1245677,'9999'),
         to_char(12,'9999'),
         to_char(234,'0000'), 
         to_char(23.234,'99.0000'),
         to_char(334455.33,'L999,999,999.00')
         from dual
 
 
 
 
/* 6
 to_date函数
 将字符串转换成日期
 前面已经使用*/
 select to_date('10 9月 1992','dd Month yyyy')
 from dual
 
 
 
 
 
/* 7
 to_number函数
 将字符串转换成数字格式, 字符串最好式数字*/
 select to_number('123') from dual
 
 
 
/* 
 8
 函数可以嵌套*/
 select to_char(
 next_day(
        add_months(sysdate,6)
        ,1)
        ,'DAY,MONTH DDTH,YYYY'
 from dual
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
/* 多表查询*/
 select * from city
 
 
/* 外连接*/
 select c.city_no,p.name_c pname,c.name_c cname
 from city c inner join province p
 on c.province_no=p.province_no
 
 selcet * from item_master_tb
 
/* 内连接*/
 select a.item_number,a.description,d.department_name
 from item_master_tb a inner join dept_master d
 on a.franchise=d.department_code
 
 
 
 
 select count(*) from item_master_tb
 where itemgroup6 is null
 
 
 
  select count(*) 
  from item_master_tb
  group by group_code
  having count(*)>1
 where itemgroup6 is null
 
 

 
 
 /*左连接*/
  /*数据要区分大小写的*/
 /* 和sql语言一样的*/

 
 
 select a.item_number,a.description,g.description 
 from item_master_tb a
 left join  itemgroup_master g
 on a.itemgroup6 =g.group_code
 where g.group_type='S6'
 t
 
 
 /*另一种写法:*/
/* 要能看懂
 +放在右边是左连接  放在左边是右连接*/
  select a.item_number,a.description,g.description 
 from item_master_tb a , itemgroup_master g
 where a.itemgroup6=g.group_code(+)
 and g.group_type= 'S6'

 
 
 
 select *from itemgroup_master
 
 
 
 select s7.group_code, s7.description,s6.description
 from itemgroup_master s7 inner join itemgroup_master s6
 on s7.parent_code=s6.group_code
 where s7.parent_code is not null
 
 
 
 
 
 
/* 分组查询
 重要
 select
 group by 
 having
 order by 
 count(*)计算所有的记录的行数
 count(ca) 计算某个字段的行数
 只有出现在group by 后面的才能出现在select,oreder by中,这是规定 
 having  和 order by 是可选的 
 having 用于进一步过滤条件,就是对分组好之后 再进一步筛选
 
 分组查询经常用到的函数:*/
 avg sum min max  count()
 
/* count()函数*/
 select count(*) total ,count(ca)
 from djzhb
 
 select * from item_master_tb
 
 
 /*
 一般都是先分组再计算平均 或 总值 */
select             franchise ,
                   avg(dist_price),
                   max(dist_price),
                   min(dist_price),
                   count(item_number) 
 
 from item_master_tb
 group by franchise 
 having avg(dist_price)>1000
 order by franchise
 
 
 
 
/* 子查询
 超级重要
/* 
 先执行嵌套在里面的  里面的先把数据进行第一步筛选  外层 以 里层为 基础 进行 查询*/
 
 
 单行数据 *//*直接用 '='*/
 select item_number,
        last_updated_time
 from item_master_tb
      where last_updated_time
      =
 (select max(last_updated_time) from item_master_tb)
 
/* 多行数据 要用 in
 也就说说  嵌套在里面的查询会返回多条记录 这种情况下要用in */
 select  item_number, franchise from item_master_tb
 where franchise in (
 select deparment_code from dept_master
 where department_type=0)
 
 
 
 
 
 create user wangshukui
  identified by "wangshukui"
  profile DEFAULT;

grant connect to wangshukui with admin option;
grant dba to wangshukui with admin option;
grant resource to wangshukui with admin option;
grant unlimited tablespace to wangshukui with admin option;













select * from customers
select * from sales



















/*连接三个表*/
select s.productid,s.customerid,s.saleprice,p.productname,c.firstname,c.lastname,s.saledate
from sales s 
inner join customers c
on c.customerid=s.customerid
inner join  products p
on p.productid=s.productid
where s.saledate >=
       to_date('2005-10-01','yyyy-mm-dd')
        and 
        s.saledate <= to_date('2005-10-30','yyyy-mm-dd')
        
        select sales s
        select s.customerid
        
        from sales s
        group by s.customerid
        having count (customerid)>=2
        
        
        
        
        
        
        
        
        
        
/*        
      必须要学好 uml 与 设计模式  重点中的重点 
      把自己心里想说的话 用工具来表达
      做成功的软件开发 
      充分调动思维  
        
        
   数据库设计概念 
   
   
   创建表*/
   
   
/*   删除表*/
   drop table S_dept
   
  /* 创建*/
   create table S_dept
   (
   /*定义主键*/
   id number(7) constraint s_dept_pk primary key, /*定义约束,式针对列的*/
   /*not null 约束*/
   name varchar2(25) constraint s_dept_name_nn not null,
   region_id number(7),
 /*  下面的约束式表级的,不是在列上,是定义好之后 在作用到表的列上,可以作用多个列*/
   constraint s_dept_name_region_id_uk unique (name,region_id) /*定义表级的约束*/
   );
   
   
   
   create table s_emp
   (
   id number(7) primary key,
   last_name varchar(25) not null,
   first_name varchar(25),
  /* 两个约束 not null 也是约束*/
   userid varchar2(8) constraint s_emp_userid_nn not null constraint s_emp_userid_uk unique,
   /*默认约束,会直接使用系统默认的时间*/
   start_date date default sysdate,
   comments varchar2(25),
   manager_id number(7),
   title varchar2(25),
   /*引用约束*/
   dept_id number(7) constraint s_emp_dept_id_fk references S_dept(id),
   salary number(11,2), 
   /*check约束*/
   commission number(4,2) constraint s_emp_commission_ck check(commmision in(10,12.5,15,20))
   );
   
   
   
   /*拷贝另一个用户的表*/
   /*只能拷贝数据,表的主键信息没有*/
   create table distributor_mastor as select * from interface.distributor_master
   
   select* from distributor_mastor
   
   
/*   在已有的表上面添加约束*/
   add constraint distributor_masterpk primary key (dist_id)
   
   
/*   oracle中的约束:
   NOT NULL
   UNIQUE
   PRIMARY KEY 
   FOREIGN KEY
   check*/
   
   
/*   default不是约束 修改一个表的列的默认值的方法:*/
   alter table s_emp
   /*modify 是修改列的*/
   modify start_date default sysdate
   
/*   
   第九章 数据字典
   了解
   系统表
   User tables*/
   
   
   select distinct object_type
   from user_objects
   
   select * from user_objects
   
 /*  查询系统中的所有对象名字*/
   select object_name from user_objects
   
   
   select object_name from user_objects
   where object_type='TABLE'
   
/*   用户表*/
   Select  * from user_tables
   
   select constraint_name,constraint_type,search_condition,
   r_constrinte_name from user_constraints where table_name='s_emp'
   
   
   
   
   
   
   
/*   
   操纵数据
   insert 
   update
   delete
   commit
   savepoint
   rellback*/
 /*  
   建表
   
   只有批处理的时候需要分号,一般处理可以不用分号*/
   create table lesson_test
   (
    std_id int not null,
    msg_id int not null,
    msg_text varchar2(200) not null,
    updatetime date default sysdate,
    primary key (std_id,msg_id)
   )
/*   插入值:*/
   insert into lesson_test 
   values(48,1,'my first message',sysdate)
   
   select  * from lesson_test
   
/*   指定null 可以直接写出来*/
   insert into lesson_test values(48,2,'myu',null)
   
/*  向表中插入部分段的数据
  没有指定则用默认值来代替*/
    insert into lesson_test(std_id, msg_id ,msg_text  ) values(48,3,'myu')
     insert into lesson_test values(48,2,'myu',null,sysdate)

/*     插入日期,通过转换 转换成日期*/
   insert into lesson_test values(48,4,'dfdf', to_date('2008-10-10','yyyy-mm-dd'))
   
   
   select * from lesson_test
   
   
   
  /* 把一个表中的数据全部提取出来赋给另一个表,
   第二个表必须要和第一个表的字段的类型一样*/
      create table lesson_test_history
   (
    std_id int not null,
    msg_id int not null,
    msg_text varchar2(200) not null,
    updatetime date default sysdate,
    primary key (std_id,msg_id)
   )
   
/*   复制语句:*/
   insert into lesson_test_history
   select * from  lesson_test
   
   
   select * from lesson_test_history
   
   
   
   
   
   
/*   
   修改数据
   update
   set*/
   
   
  /* ||相当于 c sharp 中的 + 运算符*/
   update lesson_test 
   set msg_text=msg_text|| 'Modified' 
   where std_id=48 and msg_id=4
   
   select * from lesson_test
   
   
   
   
   
/*   删除数据
   删除表中的相关数据*/
   delete from
   
/*   可以通过where指定要输出的行*/
   delete from lesson_test
    where updatetime< to_date('2008-05-01','yyyy-mm-dd')
    
    
    
    
    
/*    
    事务
    
    
    先删除表,此时数据为空*/
   delete from lesson_test
/*   对这个表设置一个回滚点*/
   savepoint A;
   
/*   插入一条记录*/
   insert into lesson_test(std_id,msg_id,msg_text,updatetime)
   values(48,6,'dddddd',to_date('2008-04-04','yyyy-mm-dd'))
   
   
     select * from lesson_test
/*     回滚到A点  A点是没有数据的*/
  rollback to A
  
/*  查看发现回滚到A的时候表的信息*/
  select * from lesson_test
   
   /*再次回滚,会把上面一条语句的信息 回滚  上面是 delete 语句 */
   rollback
/*   查询后发现 以前的数据又找回来了 */
   select  * from lesson_test
   
   
   
   
   
/*   commit
   会把数据提交给表 真正的修改表,执行查询之后 只有点击commit 才能真正的改变表中的数据
   因为所有的数据 都会 利用日志 来 保存我们的任何操作,只有 点击上面的commit 才真正写入到表中
   我们删除表中数据的时候 其实是在虚拟表中操作的 ,不会影响真正的表,只有点击上面的commit按钮 
   才会写入到表中*/
     insert into lesson_test(std_id,msg_id,msg_text,updatetime)
   values(48,5,'dddddd',to_date('2008-04-04','yyyy-mm-dd'))
   
   commit
 /*  是提交上面的操作  数据提交后  前面定义的 回滚点都会被删除*/
   
   select * from lesson_test  order by msg_id
   
   
   
   
   
   
   
 /*  修改表*/
   
   
   
 /*  前面是怎么创建表的  现在是对已经存在的表 修改
   修改列 约束
   增加列 约束
   删除列 约束
   
   
   删除表*/
   
   alter table     /*表*/
   add modify drop /*列*/
   enabled 
   
   
   
 /* 添加列*/
  select * from lesson_test 
  

  alter table lesson_test
  add comments varchar(255) null;/*添加列*/
  
  
 /* 删除列*/
  drop column comments
   
   
/*  修改列
 只能向大的方向修改 例如 原来列的字段式100个字符串 类型  ,只能向大的方向修改 例如200*/
   alter table lesson_test
   modify msg_text varchar2(200)
   
   select * from lesson_test
   
   
   
   /*
   
   主键 外键*/
   drop table lesson_test
    create table lesson_test
   (
    std_id int not null,
    msg_id int not null,
    msg_text varchar2(200) not null,
    updatetime date default sysdate,
    primary key (std_id)
   )
   
 create table lesson_test_type
 (
 msg_type int not null,
 msg_typename varchar(200),
 primary key (msg_type)
 ) 
 
 insert into lesson_test_type
 values(2,'dfdff')
 select * from lesson_test_type
 
/* 添加外键*/
 alter table lesson_test
 add  constraint s_lesson_text_id_fk 
  foreign key (msg_type)
  references lesson_test_type (msg_type)
   /*
   禁用约束*/
   alter table lesson_test 
   disable constraint s_lesson_text_id_fk
   
   
/*   启用约束*/
   alter table lesson_test 
   enable constraint s_lesson_text_id_fk
   
/*  删除表,会级联 把一切的约束 以及与表有关的都级联删除*/
   drop table lesson_test 
   cascade constraints
   
   
   
   
   
/* 修改表名*/
 
 rename lesson_test to lessonabc
 
 select* from lessonabc
 

 delete table lessonabc
 rollback
/* 不会真正删除,回滚会回到原数据,式删除临时表*/
 
 
 truncate table lessonabc
/* 真正删除数据,删除的式实际表中数据*/

 
 
 
 
 
 
 
 
 
 
 
 
 
 
/* sequences 
 专门用于产生一个不重复的数字序列 用于使得列唯一    */                   
create table dept(
id int not null,

name varchar2(200),
primary key (id))

insert into dept values(wangshukui_test_sql.nextval,'test')

select * from dept


    /* 建立sequence的语句:*/
       
       -- Create sequence 
create sequence WANGSHUKUI_TEST_SQL
minvalue 1
maxvalue 9999999
start with 201
increment by 1
cache 200
cycle;

--练习:自己创建一个sequence
create sequence sq_first1
increment by 1
start with 6534
maxvalue 34356667777888
cache 200
cycle;
 
insert into dept values(sq_first1.nextval,'test')
select * from dept



/*视图:

好处:
可以防止 直接访问 数据库, 可以保护数据  只让员工访问基础级别的数据 把其封装在试图中
*/

/*简单试图:如果涉及的表 没有 函数  只有一张表 等复杂的内容 

复杂试图 : 多表   还有函数 等 多种信息*/


/*创建视图*/
create or replace view vw_lwsson_test
as
    select std_id,msg_id,msg_text
    from lessonabc
    with read only  --表示创建只读视图
    select * from vw_lwsson_test

select * from lessonabc
insert into lessonabc values(1,2,'dff',sysdate)

--修改视图
update vw_lwsson_test
set  msg_text=msg_text || 'mod by view' 
where std_id=48 and msg_id=1

select * from vw_lwsson_test


--复杂视图
--有多个表

create or replace view vw_lesson_test2 
as
select rownum no,l.std_id,l.msg_id,l.msg_text,t.msg_typename
from lesson_test_history l,lesson_test_type t
where l.msg_id= t.msg_type


--指定别名 :
--也可以看做一个视图
--如果其他用户的某个表经常使用 可以给其指定一个简单的名称 关键字 synonym
create synonym province 
 for interface.province
 
 select * from province
 
 
 select *  from lessonabc
 --当然也可以给当前用户的某个表在起一个名字
 --查询这两个名字都可以得到这个表的信息
 create synonym  lesson 
 for lessonabc
 
 select * from lesson
 select * from lessonabc
 
 
/* 
 嘿嘿
 获取别的用户的表*/
 select * from liushuai.lesson_test_type
 
 
 
/* 索引
 就是数据结构里面的B+ 树
 index
 
 通过索引查询数据 可以缩短时间 
 
 有些索引 系统自动创建*/
 automatically
 
 unique
 
 non-unique
 single column
 concatenated 
 
 
 
/* 为某个表的一列创建索引*/
 create index temp_lesson_test
 on lesson_test_type(msg_type)
/* 删除索引*/
 drop index temp_lesson_test
 
/* 建立索引的原则 :
 一般为哪些列建立索引:
 哪些列需要建立索引
 
 如果一列经常出现在where条件里面,
 如果一列的取值范围很大
 如果一列的大部分数据为NULL
 因为:索引会把有数据的值 集中一起, 这样就会先查询有数据的
 
  如果两个或者多个列 经常组合出现在 where条件中  可以将其组合 为其建立索引
  
  如果表的数据很庞大*/
  
  
  
  
  
/*  什么情况下不用建立索引:
  
  如果 表很小 
  
  如果一列不经常使用
  如果每次查询 返回的行数 少于总行数的2-4%  也不用建立索引
  如果一个表需要经常更新 也不用建立索引  */
posted @ 2009-09-23 12:05  书奎  阅读(543)  评论(2编辑  收藏  举报