http://www.2cto.com/database/201307/225809.html

1、数据操作语言(DML:select,delete,insert,update)

<>查询数据库目录:

        db2 list db directory

 <>查询数据库中表

        db2 list tables 当前用户

        db2 list tables for all 所有表

        db2 list tables for schema schemaname 指定模式的表

 <>显示表结构

        db2 describe table tablename

 <>插入数据

        db2 insert into tablename(字段名,字段名...) values (与字段名一一对应的值)

        db2 insert into tablename1(字段1,字段2,字段3...) 

        select 字段1,字段2,字段3...from tablename2 + 查询条件

 <>更改表或视图数据

        db2 update tablename/viewname set 字段名1='',字段2='',...+查询条件

 <>删除数据

        db2 delete from tablename where + 条件   

<>导入数据

       db2 "import from E:\name.txt of del insert into tableName"

       db2 "import from E:\name.ixf of ixf commitcount 5000 insert /create/replace into tableName"

       db2 "load client from D:\xx.txt of del insert/replace into tabName"(不需要写日志,但插入前表必须存在;不能create table)

       db2 "load client from D:\xx.txt of del restart/terminate into tabName" 当导入数据出现问题被强行中断时,此表会被加锁,通过此命令可以解锁

 <>导出数据

          db2 "export to E:\name.txt of del select * from tableName"

          db2 "export to E:\name.txt of del MODIFIED BY NOCHARDEL select * from tableName"(导出不带分号的数据)

      导出表结构和数据

          db2 "export to E:\name.ixf of ixf MODIFIED BY NOCHARDEL select * from tableName"

          db2 "export to E:\name.ixf of ixf MODIFIED BY NOCHARDEL select * from tableName fetch first (取数+UNM) rows only"(取固定条数)

      导出表结构

          db2look -d dbName -e -t tableName -o D:\xxx.sql(path) -i userName -w password

          db2look -d dbName -z tabSchema -e -c -i userName -w password -o + 路径名

      导出存储过程结构

          db2 "export to xxx.sql of del select text from syscat.procedures where procname='大写存储过程名'"

   <>查询表状态

       db2 load query table + tableName

   <>查询当前表数据量(数据入库时)

       db2 select count() from tab with ur

   <>修改当前表名、模式名

       db2 rename table tab1 to tab2

2、数据定义语言(DDL:create,alter)

 <>创建或删除实例

   db2icrt instance_name/db2idrop -f instance_name

   linux:db2icrt -u user_id instance_name

  <>创建视图、表、模式

 db2 create view/table/schema

 创建指定用户的模式

 db2 create schema schName AUTHORIZATION userName

 db2 create schema AUTHORIZATION userName(没有指定模式名时,模式名隐含为用户名userName)

  定义含有缺省值的表

 db2 create table tableName(column1 数据类型,column2 数据类型 default '缺省值')

 基于已存在的表

 db2 create table clone_tablename like tablename 

 db2 create table clone_tablename as (select * from tablename) definition only

 创建物化查询表(MQT) 

 create table new_table_name as (select * from table_name) data initially deferred refresh deferred;

 refresh table new_table_name;
注意:物化表类似一个查询,没有真正形成表,类型显示为Query。但它完全可以当表来用。
 
               创建表并指定其索引表空间
  db2 create table(.....) in userspace1 INDEX in userspace2 (userspace1是表所在空间,userspace2是表上索引所在空间) 
 
 
<3>创建视图
 db2 create view viewname 

        as select 字段名1,字段名2...from table where + 条件

 with check option 规定一种约束:通过视图插入或更新的每一行都必须符合视图的定义,如:

 create view emp_view2(empno,empname,deptno) as (select id,name,dept from employee where dept=)with check option

 当此视图用于更新数据或插入新值时,with check option 限制了dept列的输入值

<4>修改表(列,主键,唯一约束,检查约束)

 )添加新列 alter table tablename ADD COLUMN columnname 数据类型

  )添加约束 

  )修改表中字段 alter table tablename alter columnname set data type 数据类型

  ) 添加主键 alter table tablename add primary key(c1,c2)

 <>删除模式、表、视图

    drop schema schName <CASCADE|RESTRICT>

    CASCADE(级联)表示删除模式的同时删除该模式中所有的数据库对象

    RESTRICT(限制)表示该模式下定义了数据库对象时,限制删除;没有任何数据库对象时才能删除

 <>重新组织表及其索引

    重组表数据  reorg table tableName index indexName(根据索引)

    重组表索引  reorg indexes all for table tableName

 <>重新收集表及其索引统计信息

    runstats on table tableName for indexes all(跑批前重新收集所用表信息可以提高效率)

 <>DB2自动增长主键方法

    IDENTITY列

      generated always as identity(start with ,increment by )将一个字段指定为自增长型字段,放在数据类型后。
SEQUENCE对象(序列)
 
 
3、数据控制语言(DCL:grant,revoke)
 将表的特权授予用户

 grant select,update,delete on table tableName to user userName with grant option

 将包特权授予同组

 grant control on package packageName on group groupName with grant option

DB2语句详细资料的更多相关文章

  1. DB2 公共表表达式(WITH语句的使用)

    ----start 说起WITH 语句,除了那些第一次听说WITH语句的人,大部分人都觉得它是用来做递归查询的.其实那只是它的一个用途而已,它的本名正如我们标题写的那样,叫做:公共表表达式(Commo ...

  2. db2笔记

    第七章:数据库备份与恢复 (恢复的概念,db2日志,数据库和表空间的备份,数据库和表空间的恢复,数据库和表空间的前滚,recover使用程序,数据库重建,监控备份恢复和复原,优化备份恢复和复原)1) ...

  3. DB2 错误 54001

    DB2 语句太长或者太复杂 SQLSTATE=54001 对数据库的参数的修改: db2 update db cfg for DB_NAME using STMTHEAP 4096 db2 updat ...

  4. db2构建临时结果集

    一 values  ('1',2,3)   为一行   ‘1’   2    3   行数据类型可以不同  values  ('1',2,3),('f',5,6) 为两行 (values  1,2,3 ...

  5. whdxlib

    1 数据库系统实现 实 验 指 导 书 齐心 彭彬 计算机工程与软件实验中心 2016 年 3 月2目 录实验一.JDBC 应用程序设计(2 学时) ......................... ...

  6. spring-mvc.xml 和 application-context.xml的配置与深入理解

    在java框架这个话题,前几篇文章是基于搭建ssm项目框架,以及web.xml的配置讲解,本篇主要就ssm框架的其他配置文件进行深入讲解,他们分别是:1.application-context.xml ...

  7. python第六天 函数 python标准库实例大全

    今天学习第一模块的最后一课课程--函数: python的第一个函数: 1 def func1(): 2 print('第一个函数') 3 return 0 4 func1() 1 同时返回多种类型时, ...

  8. 数据库(MSSQLServer,Oracle,DB2,MySql)常见语句以及问题

    创建数据库表 create table person ( FName varchar(), FAge int, FRemark varchar(), primary key(FName) ) 基本sq ...

  9. Oracle、DB2、SQLSERVER、Mysql、Access分页SQL语句梳理

    最近把平时在项目中常用到的数据库分页sql总结了下.大家可以贴出分页更高效的sql语句.sqlserver分页 第一种分页方法 需用到的参数: pageSize 每页显示多少条数据 pageNumbe ...

随机推荐

  1. js 判断移动设备、pc端、android、iPhone、是否为微信、微博、qq空间

    varbrowser = {   versions: function () {      var u = navigator.userAgent, app = navigator.appVersio ...

  2. C++ STL中的 iterator 和 const_iterator

    我们在C++中使用STL的容器时,经常会用到迭代器.使用迭代器可以很方便的进行容器元素遍历和修改等操作. 近日,在使用Visual Studio 2015编程的时候发现,set的迭代器直接就是cons ...

  3. 市面上主流服务器简单介绍(apache、IIS、tomcat..)

    apache:apache(阿帕奇)的具体介绍可以参看apache的网站(http://www.apache.org/),或者在网上随便搜搜吧.apache是世界使用排名第一的web服务器软件:它可以 ...

  4. Easyui-combobox-checkbox-带复选框的下拉框

    $.post("getSubInsuranceTypeList.do",{parent_id:node.id},function(result){                  ...

  5. 移动APP的开发需求分析

    一.项目概况 项目名称为上海地铁游.本项目是以上海地铁为线索,开发的一个移动APP.主要目的是帮助用户实现根据当前位置选择最方便的地铁旅游点和旅游推荐,方便出行,让更多人可以借助地铁的便利去认识和体验 ...

  6. treetable 前台 累计计算树值 提交后台

    treetable   累计计算树值 效果图 html  代码 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//E ...

  7. 内置函数callable(object)

    如果对象object参数是可以调用的对象,就返回True:否则返回False.不过要注意的是,当一个对象是可以调用的,并不表示调用该对象时执行一定成功,但不可调用的对象去调用时一定不会成功.如果类对象 ...

  8. Qt 设计师手册

    Qt设计师(Qt Designer)是使用Qt部件(Widgets)设计和使用图形用户界面(GUI)的工具.它允许我们以所见即所得的方式构建和定制自己的窗口(Windows)或对话框(Dialogs) ...

  9. html5视屏背景注意事项。

    在动手编码实现前,视频作为网页背景的有些问题我们要先考虑清楚: 并不是因为技术上可行你就可以任意使用:作为背景的视频内容必须能增强页面内容的感染力,而不是因为漂亮或技术上很酷就使用它. 作为背景的视频 ...

  10. Oracle数据库体系结构、启动过程、关闭过程

    一.Oracle数据库体系结构体系结构由下面组件组成:1.Oracle服务器(Server):由数据库实例和数据库文件组成,另外在用户建立与服务器的连接时启动服务器进程并分配PGA(程序全局区) (1 ...