DB2常用命令小结
- 格式:doc
- 大小:30.50 KB
- 文档页数:13
db2常⽤命令(详解)⼤全近⼀年来在项⽬开发中使⽤到了IBM的DB2 9.1的数据库产品,跟Oracle相⽐⼀些命令有很⼤的区别,⽽它最⼤的功能是⽀持xml存储、检索机制,通过XPath进⾏解析操作,使开发⼈员免于对xml⽂件在应⽤进⾏解析处理,先对其常⽤命令进⾏⼀下汇总,以免遗忘。
注意:在执⾏如下命令时,需要⾸先安装db2客户端并通过在运⾏中输⼊db2cmd进⾏初始化⼀、基础篇1、db2 connect to <数据库名> --连接到本地数据库名db2 connect to <数据库名> user <⽤户名> using <密码> --连接到远端数据库2、 db2 force application all --强迫所有应⽤断开数据库连接3、db2 backup db db2name<数据库名称> --备份整个数据库数据db2 restore db <db2name> --还原数据库4、db2 list application --查看所有连接(需要连接到具体数据库才能查看)5、db2start --启动数据库db2stop --停⽌数据库6、create database <数据库名> using codeset utf-8 territory CN--创建数据库使⽤utf-8编码7、db2 catalog 命令db2 catalog tcpip node <接点名称> remote <远程数据库地址> server <端⼝号>--把远程数据库映射到本地接点⼀般为50000db2 catalog db <远程数据库名称> as <接点名称> at node PUB11--远程数据库名称到本地接点db2 CONNECT TO <接点名称> user <⽤户名> using <密码>--连接本地接点访问远程数据库8、数据库导出db2look -d <数据库名> -u <⽤户> -e -o <脚本名称>.sql--导出数据库的表结构,其中⽤户空间⼀般为db2admin/db2inst1db2look -d <数据库名> -u <⽤户> -t <表1> <表2> -e -o <脚本名称>.sql--导出数据库中表1和表2的表结构db2move <数据库名> export --导出数据库数据db2move <数据库名> export -tn <表1>,<表2> --导出数据库中表和表数据 db2move dbname export;db2move dbname import db2move bipdbrun export -sn app -u app -p app9、数据库导⼊db2 -tvf <脚本名称>.sql --把上述导出的表结构导⼊到数据库表结构db2move <数据库名> load -lo replace --把上述“db2move <数据库名> export“导出的数据导⼊到数据库中并把相同的数据替换掉在实际使⽤过程中,如果⽤到db2⾃增主键,需要使⽤by default,⽽不是always,功能是⼀样的,但这样在数据移植时候会很⽅便!10、db2 connect reset 或 db2 terminate --断开与数据库的连接11、db2set db2codepage=1208 --修改页编码为120812、db2 describe table <表名> --查看表结构13、db2 list tables --查看数据库中所有表结构list tables for system --列出所有系统表14、db2 list tablespaces --列出表空间⼆、⾼级篇15、fetch first 10 rows only --列出表中前10条数据例如:select * from <表名> fetch first 10 rows only16、coalesce(字段名,转换后的值) --对是null的字段进⾏值转换例如:select coalesce(id,1) from <表名> --对表中id如果为null转换成117、dayofweek(⽇期) --计算出⽇期中是周⼏(1是周⽇,2是周⼀.......7是周六)dayofweek_iso --计算出⽇期中是周⼏(1是周⼀.......7是周⽇)例如:dayofweek(date(2008-01-16)) --它会返回是4,代表星期三dayofweek_iso(date(2008-01-16)) --它会返回是3,代表星期三18、dayofyear(⽇期) --⼀年中的第⼏天,范围在1-366范围之内注意:参数中⽇期的格式是YYYY-MM-DD的形式,如果不是需要进⾏转换,否则函数不能使⽤例如:⽇期是20080116必须要进⾏转换dayofweek(concat(concat(concat(substr(openDate,1,4),'-'),concat(substr(openDate,5,2),'-')),substr(openDate,7,2)))as week)这样格式正确的。
DB2数据库的常用操作指令DB2是一种关系型数据库管理系统,其常用操作指令可以帮助用户在数据库中执行各种操作。
以下是DB2数据库的一些常用操作指令。
1.连接数据库:CONNECT TO database_name [USER username USING password]2.断开数据库连接:CONNECTRESET3.创建表:CREATE TABLE table_name (column1 datatype, column2 datatype, ...)4.删除表:DROP TABLE table_name5.修改表结构:ALTER TABLE table_name ALTER COLUMN column_name SET DATA TYPE datatype6.插入数据:INSERT INTO table_name (column1, column2, ...) VALUES (value1, value2, ...)7.更新数据:UPDATE table_name SET column1 = value1, column2 = value2 WHERE condition8.删除数据:DELETE FROM table_name WHERE condition9.查询数据:SELECT column1, column2, ... FROM table_name WHERE condition 10.创建索引:CREATE INDEX index_name ON table_name (column1, column2, ...)11.删除索引:DROP INDEX index_name12.创建视图:CREATE VIEW view_name AS SELECT column1, column2, ... FROM table_name WHERE condition13.修改视图:ALTER VIEW view_name AS SELECT column1, column2, ... FROM table_name WHERE condition14.删除视图:DROP VIEW view_name15.创建存储过程:CREATE PROCEDURE procedure_name (parameter1 datatype, parameter2 datatype, ...)LANGUAGESQLBEGIN--存储过程代码END16.删除存储过程:DROP PROCEDURE procedure_name17.创建触发器:CREATE TRIGGER trigger_name BEFORE/AFTERINSERT/UPDATE/DELETE ON table_nameREFERENCING OLD ROW AS old NEW ROW AS newFOREACHROW--触发器代码18.删除触发器:DROP TRIGGER trigger_name19.提交事务:COMMIT20.回滚事务:ROLLBACK21.创建数据库:CREATE DATABASE database_name22.删除数据库:DROP DATABASE database_name以上是DB2数据库的一些常用操作指令,可以帮助用户在数据库中执行各种操作。
DB2数据库 SQL常用命令一、连接数据库1. 从命令行连接数据库- 语法: db2 connect to <database_name> user <username> using <password>- 示例: db2 connect to sample user db2inst1 using passw0rd2. 从命令行断开数据库连接- 语法: db2 connect reset- 示例: db2 connect reset3. 显示当前连接的数据库- 语法: db2 list database directory- 示例: db2 list database directory二、管理数据库对象4. 创建数据库- 语法: db2 create database <database_name>- 示例: db2 create database sample5. 删除数据库- 语法: db2 drop database <database_name>- 示例: db2 drop database sample6. 创建表- 语法: db2 create table <table_name> (<column1_name> <data_type>, <column2_name> <data_type>, ...)- 示例: db2 create table employee (id int, name varchar(50), age int)7. 删除表- 语法: db2 drop table <table_name>- 示例: db2 drop table employee8. 插入数据- 语法: db2 insert into <table_name> values (<value1>,<value2>, ...)- 示例: db2 insert into employee values (1, 'John', 25)9. 删除数据- 语法: db2 delete from <table_name> where <condition> - 示例: db2 delete from employee where id = 110. 更新数据- 语法: db2 update <table_name> set <column_name> =<new_value> where <condition>- 示例: db2 update employee set age = 30 where id = 111. 查询数据- 语法: db2 select <column1_name>, <column2_name>, ... from <table_name> where <condition>- 示例: db2 select * from employee三、管理数据库事务12. 启动事务- 语法: db2 autmit off- 示例: db2 autmit off13. 提交事务- 语法: db2mit- 示例: db2mit14. 回滚事务- 语法: db2 rollback- 示例: db2 rollback四、管理数据库权限15. 创建用户- 语法: db2 create user <username> password <password> - 示例: db2 create user testuser password testpass16. 授权- 语法: db2 grant <privilege> on <object> to <user>- 示例: db2 grant select, insert, update on employee to testuser17. 撤销授权- 语法: db2 revoke <privilege> on <object> from <user> - 示例: db2 revoke select, insert, update on employee from testuser五、管理数据库性能18. 优化SQL查询- 语法: db2expln -d <database_name> -t <sql_statement> - 示例: db2expln -d sample -t "select * from employee"19. 查看数据库锁- 语法: db2 list applications show det本人l- 示例: db2 list applications show det本人l20. 查看数据库表空间使用情况- 语法: db2pd -d <database_name> -tablespaces- 示例: db2pd -d sample -tablespaces六、其他常用命令21. 导出数据- 语法: db2 export to <file_name> of del select * from<table_name>- 示例: db2 export to employee.csv of del select * from employee22. 导入数据- 语法: db2 import from <file_name> of del insert into<table_name>- 示例: db2 import from employee.csv of del insert into employee23. 查看数据库配置参数- 语法: db2 get db cfg for <database_name>- 示例: db2 get db cfg for sample结语以上就是DB2数据库SQL常用命令的介绍,通过掌握这些命令,可以更方便地管理和使用DB2数据库。
DB2命令大全.txt女人谨记:一定要吃好玩好睡好喝好。
一旦累死了,就别的女人花咱的钱,住咱的房,睡咱的老公,泡咱的男朋友,还打咱的娃。
db2常用命令大全EXPOR T TOD:\PR INTXM L.IXF OF I XF近一年来在项目开发中使用到了IBM的DB29.1的数据库产品,跟Orac le相比一些命令有很大的区别,而它最大的功能是支持xml存储、检索机制,通过XPath进行解析操作,使开发人员免于对xml文件在应用进行解析处理,先对其常用命令进行一下汇总,以免遗忘。
注意:在执行如下命令时,需要首先安装d b2客户端并通过在运行中输入d b2cmd 进行初始化一、基础篇1、db2conne ct to <数据库名> --连接到本地数据库名 db2conne ct to <数据库名> us er <用户名> u sing<密码>--连接到远端数据库2、db2 f orceappli catio n all --强迫所有应用断开数据库连接3、d b2 ba ckupdb db2name<数据库名称> --备份整个数据库数据d b2 re store db <db2na me> --还原数据库4、db2 l ist a pplic ation --查看所有连接(需要连接到具体数据库才能查看)5、d b2sta rt --启动数据库db2st op --停止数据库6、c reate data base<数据库名> usi ng co deset utf-8 ter ritor y CN --创建数据库使用utf-8编码7、db2 cat alog命令db2 c atalo g tcp ip no de <接点名称>remot e <远程数据库地址> ser ver <端口号> --把远程数据库映射到本地接点一般为50000db2catal og db <远程数据库名称> as <接点名称> atnodePUB11 --远程数据库名称到本地接点d b2 CO NNECT TO <接点名称> user <用户名> usi ng <密码> --连接本地接点访问远程数据库8、数据库导出db2lo ok -d <数据库名> -u <用户> -e -o <脚本名称>.s ql --导出数据库的表结构,其中用户空间一般为db2a dmin/db2in st1db2lo ok -d <数据库名> -u <用户> -t <表1> <表2> -e -o <脚本名称>.sq l --导出数据库中表1和表2的表结构db2move <数据库名> ex port --导出数据库数据d b2mov e <数据库名> e xport -tn<表1>,<表2> --导出数据库中表和表数据9、数据库导入db2 -tvf <脚本名称>.sql --把上述导出的表结构导入到数据库表结构d b2mov e <数据库名> l oad -lo re place --把上述“d b2mov e <数据库名> e xport “导出的数据导入到数据库中并把相同的数据替换掉在实际使用过程中,如果用到db2自增主键,需要使用by defa ult,而不是al ways,功能是一样的,但这样在数据移植时候会很方便!10、d b2 co nnect rese t 或d b2 te rmina te --断开与数据库的连接11、db2set d b2cod epage=1208 --修改页编码为120812、db2 d escri be ta ble <表名> --查看表结构13、db2 list tabl es --查看数据库中所有表结构d b2 li st ta blesfor s ystem --列出所有系统表14、db2listtable space s --列出表空间二、高级篇15、f etchfirst 10 r ows only --列出表中前10条数据例如:s elect * fr om <表名> fe tch f irst10 ro ws on ly16、coa lesce(字段名,转换后的值) --对是nul l的字段进行值转换例如:s elect coal esce(id,1) fro m <表名> --对表中id如果为null转换成117、da yofwe ek(日期) --计算出日期中是周几(1是周日,2是周一.......7是周六) da yofwe ek_is o --计算出日期中是周几(1是周一.......7是周日)例如:dayof week(date(2008-01-16)) --它会返回是4,代表星期三dayof week_iso(d ate(2008-01-16)) --它会返回是3,代表星期三18、da yofye ar(日期) --一年中的第几天,范围在1-366范围之内注意:参数中日期的格式是YYYY-MM-DD的形式,如果不是需要进行转换,否则函数不能使用例如:日期是20080116必须要进行转换da yofwe ek(co ncat(conca t(con cat(s ubstr(open Date,1,4),'-'),conca t(sub str(o penDa te,5,2),'-')),s ubstr(open Date,7,2))) asweek)这样格式正确的。
db2数据库常用语句【db2数据库常用语句】是一个涉及DB2数据库的常用查询语句和操作语句集合。
在以下文章中,我将逐步回答关于DB2数据库常用语句的问题,以帮助读者更深入了解和使用DB2数据库。
第一部分:介绍DB2数据库和SQL语言首先,让我们了解一下DB2数据库和SQL语言。
DB2是IBM公司开发的一种关系型数据库管理系统(RDBMS),已经成为很多企业和组织中使用得最广泛的数据库之一。
它支持SQL(结构化查询语言),这是一种用于管理数据库的通用语言。
第二部分:DB2数据库常用查询语句在DB2数据库中,我们可以使用各种查询语句来检索和过滤数据。
以下是一些常用的查询语句:1. SELECT语句:SELECT语句用于从数据库中检索数据。
例如,SELECT * FROM 表名将返回该表中的所有行和列。
2. WHERE子句:WHERE子句用于添加筛选条件到查询语句中。
例如,SELECT * FROM 表名WHERE 列名= 值将只返回符合条件的行。
3. ORDER BY语句:ORDER BY语句用于对结果进行排序。
例如,SELECT * FROM 表名ORDER BY 列名ASC将按升序对结果集进行排序。
4. GROUP BY语句:GROUP BY语句用于根据一个或多个列对结果进行分组。
例如,SELECT 列名FROM 表名GROUP BY 列名将返回每个不同值的分组。
第三部分:DB2数据库常用操作语句除了查询语句,我们还可以使用操作语句来修改和管理数据库。
以下是一些常用的操作语句:1. INSERT语句:INSERT语句用于向数据库中插入新的行。
例如,INSERT INTO 表名(列名1, 列名2, ...) VALUES (值1, 值2, ...)将在指定的列中插入新的值。
2. UPDATE语句:UPDATE语句用于更新数据库中的现有数据。
例如,UPDATE 表名SET 列名= 新值WHERE 列名= 条件将更新满足条件的行中的列的值。
DB2数据库的操作命令总结以下是DB2数据库的操作命令总结:1. 连接数据库:CONNECT TO database_name USER username USING password使用CONNECTTO命令可以连接到特定的数据库,需要提供数据库的名称、用户名和密码。
2. 断开数据库连接:DISCONNECT database_name使用DISCONNECT命令可以断开与数据库的连接。
3. 创建数据库:CREATE DATABASE database_name使用CREATEDATABASE命令可以创建一个新的数据库。
4. 删除数据库:DROP DATABASE database_name使用DROPDATABASE命令可以删除一个已经存在的数据库。
5.列出所有数据库:LISTDATABASEDIRECTORY使用LISTDATABASEDIRECTORY命令可以列出所有的数据库。
6. 切换数据库:CONNECT TO database_name使用CONNECTTO命令可以切换到另一个已存在的数据库。
7. 创建表:CREATE TABLE table_name (column1 datatype1, column2 datatype2, ...)使用CREATETABLE命令可以创建一个新的表,需要提供表名和各个列的名称及数据类型。
8. 删除表:DROP TABLE table_name使用DROPTABLE命令可以删除一个已经存在的表。
9. 查询表的结构:DESCRIBE TABLE table_name使用DESCRIBETABLE命令可以查询一个表的结构,包括各个列的名称和数据类型。
10. 查询表的数据:SELECT * FROM table_name使用SELECT命令可以查询一个表中的数据,使用*表示查询所有的列。
11. 插入数据:INSERT INTO table_name (column1, column2, ...) VALUES (value1, value2, ...)使用INSERTINTO命令可以向一个表中插入新的数据,需要提供插入的列和相应的值。
db2常用命令0.进入db2命令环境db2cmd1.启动db2db2start;2.关闭db2db2stop;db2stop force;3.创建数据库db2 create db ;db2 create db using codeset GBK territory CN;db2 Create database using codeset IBM-eucCN territory CN;这样可以支持中文。
4.删除数据库(执行此操作要小心)db2 drop db如果不能删除,断开所有数据库连接或者重启db2。
5.断开数据库连接db2 force application all6.连接数据库db2 connect to user using7.断开数据库连接断开当前数据库连接:db2 connect reset或者:db2 disconnect current断开所有数据库的连接:db2 disconnect all8.备份数据库db2 backup db备注:执行以上命令之前需要断开数据库连接9.恢复数据库db2 restore db10.导出数据文件db2move export [-sn <模式名称,一般为db2admin>] [-tn <表名,多个之间用逗号分隔>]; 更多时候用下面这种方式:db2 export to test.ixf of ixf select * from11.导入数据文件db2move importdb2 import from text.ixf of ixf create into ;(表不存在)db2 import from text.ixf of ixf insert into ;(表已经存在)12.建立映像:db2 catalog tcpip node nodename remote 10.0.2.3 server 50000db2 catalog db dbname at node nodename13.撤销映像:db2 uncatalog db dbname14.列出数据库中所有db:db2 list db directory15.获取建表脚本:db2look -d dbname -e -t tablename -a -x -i userId -w password -o filename.sql-d: 数据库名:这必须指定-e: 抽取复制数据库所需要的 DDL 文件-u: 创建程序标识:若 -u 和 -a 都未指定,则将使用 $USER-z: 模式名:如果同时指定了 -z 和 -a,则将忽略 -z-t: 生成指定表的统计信息-h: 更详细的帮助消息-o: 将输出重定向到给定的文件名-a: 为所有创建程序生成统计信息-m: 在模拟方式下运行 db2look 实用程序-c: 不要生成模拟的 COMMIT 语句-r: 不要生成模拟的 RUNSTATS 语句-l: 生成数据库布局:数据库分区组、缓冲池和表空间。
DB2总结⼀、DB2笔记d b2⾥需要⽤到⼀个系统环境变量:d b2c o de p a g e,缺省值是1386,在江苏电⼒,⼀般情况下d b2c o d e p a g e=437。
新安装数据库客户端的机器在D B2C O M M A N DW I N D O W S中执⾏语句:D B2S E T D B2C O D E P A G E=437,否则⽆法正确连上服务器。
设置环境变量命令:D: db2set db2codepage=1386查看环境变量命令:db2setd:\winnt\system32\drivers\etc\services⽂件是对机器名到IP地址的解析。
d:\winnt\system32\drivers\etc\hosts⽂件是对端⼝名到端⼝号的解析。
以上两条上⾮DB2的,但在DB2中使⽤到。
DB2⾥对⼀个命令的HELP是:>db2 ? 该命令db2 连接到远程数据库第⼀步建⼀个结点:>db2 catalog tcpip node 结点名 remote 数据库服务器IP地址 server 端⼝(50000)第⼆步建⼀个到库的联结别名:>db2 catalog db 库名 as 别名 at node 结点名第三步建⽴联结:>db2 connect to 别名 user ⽤户名 using ⽤户密码db2⾥需要⽤到⼀个系统环境变量:db2codepage,缺省值是1386,此值⾮常重要,客户端于数据库端的db2codepage不⼀样时客户端就⽆法连上数据库端。
电⼒部门,⼀般情况下db2codepage=437。
DB2⾥⼀个表的全名是:schema.表名,缺什情况下不同的⽤户看到的表是不⼀样的,在程序的sql语句⾥必需⽤表的全名(切记)。
查看有哪些程序在使⽤该数据库:>db2 list application其结果中有⼀个字段application-handle在杀死该引⽤中⽤到杀死⼀个程序对该数据库的使⽤:>db2 force application {all | (application-handle)}在库被使⽤时db2stop不能执⾏DB2命令后所带参数:-t 以;作为⼀句结束-f 指向⼀个⽂件(即执⾏⼀个⽂件中的语句,在command窗⼝⾥有些命令⽆法执⾏,可先⽤notepad建⼀个⽂件然后执⾏它)-v (我不知道是什么)注释:-v⽤于显⽰当前所执⾏的sql命令。
DB2常用函数总结DB2是一种关系型数据库管理系统,它具有强大的功能和丰富的函数库。
本文将总结一些DB2常用的函数,以帮助开发人员更好地使用DB2数据库。
1.字符串函数:-LENGTH:返回一个字符串的长度。
-CONCAT:将两个或多个字符串合并成一个字符串。
-SUBSTR:截取一个字符串的指定部分。
-LOWER:将一个字符串转换为小写。
-UPPER:将一个字符串转换为大写。
-TRIM:去除字符串的前后空格。
-REPLACE:替换一个字符串中的指定子字符串。
2.数字函数:-SUM:求一列数值的和。
-AVG:求一列数值的平均值。
-MAX:求一列数值的最大值。
-MIN:求一列数值的最小值。
-COUNT:统计一列数值的个数。
3.日期和时间函数:-CURRENT_DATE:返回当前日期。
-CURRENT_TIME:返回当前时间。
-CURRENT_TIMESTAMP:返回当前日期和时间。
-DATE:从日期和时间中提取日期部分。
-TIME:从日期和时间中提取时间部分。
-TIMESTAMP:将日期和时间组合为一个时间戳。
4.聚合函数:-GROUP_CONCAT:将一列值连接成一个字符串。
-GROUP_SUM:对一列值进行分组求和。
-GROUP_AVG:对一列值进行分组求平均值。
-GROUP_MAX:对一列值进行分组求最大值。
-GROUP_MIN:对一列值进行分组求最小值。
-GROUP_COUNT:对一列值进行分组计数。
5.高级函数:-ROW_NUMBER:为查询结果中的每一行分配一个唯一的编号。
-RANK:为查询结果中的每一行分配一个排名。
-DENSE_RANK:为查询结果中的每一行分配一个排名,相同值的行具有相同的排名。
-NTILE:将查询结果中的行分成指定数量的组,每个组具有相同数量的行。
-LAG:获取查询结果中前一行的值。
-LEAD:获取查询结果中下一行的值。
总结:本文总结了一些DB2常用的函数,包括字符串函数、数字函数、日期和时间函数、聚合函数以及一些高级函数。
db2分区表命令和总结1. 分区表相关的系统对象视图syscat.tables -- 表信息sysibm.systables ---表信息syscat.datapartitions --分区表信息syscat.datapartitionexpression --分区表分区字段字段信息2.分区表特性⽀持MINVALUE、MAXVALUE;⽀持值的上下边界限制,INCLUSIVE、EXCLUSIVE;仅⽀持range 的⼀级分区(⽬前);⽀持多字段的分区键;注:db2 using hashing 为distrubute by hash()分布表的意思,与分区表概念不同。
--新建分区表create table test_part (c1 int not null , c2 varchar(20), c3 varchar(8) not null) partition by range(c3)(starting '20210101',statring '20210401' ending '20210630',statring '20210701' ending '20210930',statring '20211001' ending '20211231') data capture changes--查看表分区⽅式⼀:SELECT * FROM SYSCAT.datapartitions WHERE TABNAME='TEST_PART'⽅式⼆:db2 describe data partitions for table TEST_PART--添加表分区alter table table_name add partition statis_month STARTINT'201301' INCLUSIVE ENDING '20090102' INCLUSIVE--收集信息db2 runstats on table schema.table_name--使⽤的页select tabname, npages from syscat.tables where tabname = 'table_name'--数据占⽤空间select tabname, npages*16384/(1024*1024) from syscat.tables where tabname = 'XXXXXX'3. 分区数据删除db2 "create table t1 (id int, age int) partition by range(age)(partition part1 starting 1 ending 18, partition part2 starting 19 ending 60, partition part3 starting 61 ending 80)"db2 "alter table t1 ACTIVATE COLUMN ACCESS CONTROL" --开启列访问控制db2 "insert into t1 values (1,2),(2,8),(3,10),(4,20),(5,22),(6,61)" --开启列访问控制db2 "alter table t1 detach partition part1 into t1_part1" --删除分区数据,移动到新表db2look -d tstdb -a -e -t t1_part1 --查看ddldb2 "alter table DB2TST.T1_PART1 DEACTIVATE ROW ACCESS CONTROL" --新表的去除⾏访问限制4.分区数据查看--select * from tet parttion(p1); --db2不⽀持⽤以下⽅式:select * from TEST_PART2 where (c1,c3) between (10,'20210201') and (12, '20210228') and (c1,c3) != (12, '20210228');。
DB2创建表、操作表等常⽤命令⼀、创建库表1、创建库1).创建数据语句CREATE DATABASE MEDIA ON /db2data USING CODESET UTF-8 TERRITORY CN ;2).创建BUFFERPOOLCONNECT TO MEDIA user db2admin using password;CREATE BUFFERPOOL "BP_MEDIA_32K" SIZE 100000 PAGESIZE 32768 NOT EXTENDED STORAGE;COMMIT WORK;CONNECT RESET;TERMINATE;;3).创建表空间connect to media user db2admin using password;CREATE REGULAR TABLESPACE "TB_MEDIA" IN DATABASE PARTITION GROUP IBMDEFAULTGROUP PAGESIZE 32768 MANAGED BY DATABASEUSING (FILE '/db2data/TB_MEDIA_C1'320000) EXTENTSIZE 32 PREFETCHSIZE 32 BUFFERPOOL BP_MEDIA_32K OVERHEAD 12.500000TRANSFERRATE 0.130000 FILE SYSTEM CACHING DROPPED TABLE RECOVERY OFF;CREATE LARGE TABLESPACE "TB_MEDIA_LOB" IN DATABASE PARTITION GROUP IBMDEFAULTGROUP PAGESIZE 32768 MANAGED BY DATABASEUSING (FILE '/db2data/TB_MEDIA_LOB_C1'640000) EXTENTSIZE 32 PREFETCHSIZE 32 BUFFERPOOL BP_MEDIA_32K OVERHEAD 12.500000TRANSFERRATE 0.130000 FILE SYSTEM CACHING DROPPED TABLE RECOVERY ON;CREATE REGULAR TABLESPACE "TB_MEDIA_IDX" IN DATABASE PARTITION GROUP IBMDEFAULTGROUP PAGESIZE 4096 MANAGED BY DATABASEUSING (FILE '/db2data/TB_MEDIA_IDX_C1'1280000) EXTENTSIZE 32 PREFETCHSIZE 32 BUFFERPOOL IBMDEFAULTBP OVERHEAD 12.500000TRANSFERRATE 0.130000 FILE SYSTEM CACHING DROPPED TABLE RECOVERY OFF;CREATE SYSTEM TEMPORARY TABLESPACE "TB_MEDIA_TMP" IN DATABASE PARTITION GROUP IBMTEMPGROUP PAGESIZE 32768 MANAGED BY SYSTEM USING ('/db2data/TB_MEDIA_TMP_C1' ) EXTENTSIZE 16 PREFETCHSIZE 16 BUFFERPOOL "BP_MEDIA_32K" OVERHEAD 12.5 TRANSFERRATE 0.13; DROP TABLESPACE USERSPACE1;-- Mimic tablespace-- ALTER TABLESPACE SYSCATSPACE PREFETCHSIZE AUTOMATIC OVERHEAD 7.500000 FILE SYSTEM CACHING TRANSFERRATE 0.060000;-- ALTER TABLESPACE TEMPSPACE1 PREFETCHSIZE AUTOMATIC OVERHEAD 7.500000 FILE SYSTEM CACHING TRANSFERRATE 0.060000;COMMIT WORK;CONNECT RESET;TERMINATE;;⼆、备份数据库1)、按表备份与恢复备份:a、导出创建表语句db2look -d media -e -c -o media.ddl -i db2admin -w passwordb、导出数据db2 connect to media user db2admin using password db2 "EXPORT TO B_NEWS.IXF OF IXF MESSAGES B_NEWS.LOG SELECT * FROM DB2ADMIN.B_NEWS"也可以,上⾯内容复制到export.sh中,执⾏以下命令./export.sh恢复:a、导⼊表结构db2 -tvf media.ddlb、导⼊数据db2 connect to MEDIA user db2admin using passworddb2 IMPORT FROM B_NEWS.IXF OF IXF MESSAGES B_NEWS.MSG INSERT INTO DB2ADMIN.B_NEWS也可以,上⾯内容复制到import.sh中,执⾏以下命令./import.sh2)、整库备份与恢复备份:a、⾸先要断开所有链接。
DB2操作指南及命令大全1.启动实例(db2inst1):db2start2.停止实例(db2inst1):db2stop3.列出所有实例(db2inst1)db2ilist4.列出当前实例:db2 get instance5.设置当前实例set db2instance=db26.察看示例配置文件:db2 get dbm cfg|more7.更新数据库管理器参数信息:db2 update dbm cfg using para_name para_value 8.创建数据库:db2 create db test9.察看数据库配置参数信息db2 get db cfg for test|more10.更新数据库参数配置信息db2 update db cfg for test using para_name para_value 11.删除数据库:db2 drop db test12.连接数据库db2 connect to test13.列出所有表空间的详细信息。
db2 list tablespaces show detail14.列出容器的信息db2 list tablespace containers for tbs_id show detail15.创建表:db2 ceate table tb1(id integer not null,name char(10))16.列出所有表db2 list tables7.插入数据:db2 insert into tb1 values(1,’sam’);db2 insert into tb2 values(2,’smitty’);18.查询数据:db2 select * from tb19.数据:db2 delete from tb1 where id=10.创建索引:db2 create index idx1 on tb1(id);1.创建视图:db2 create view view1 as select id from tb12.查询视图:db2 select * from view13.节点编目db2 catalog tcp node node_name remote server_ip server server_port 4.察看端口号db2 get dbm cfg|grep SVCENAME5.测试节点的附接db2 attach to node_name6.察看本地节点db2 list node direcotry7.节点反编目db2 uncatalog node node_name8.数据库编目db2 catalog db db_name as db_alias at node node_name9.察看数据库的编目db2 list db directory0.连接数据库db2 connect to db_alias user user_name using user_password 1.数据库反编目db2 uncatalog db db_alias2.导出数据db2 export to myfile of ixf messages msg select * from tb1 3.导入数据db2 import from myfile of ixf messages msg replace into tb1 如有问题用:import from c:/backup/usercar of ixf create into usercar4.导出数据库的所有表数据db2move test export5.生成数据库的定义db2look -d db_alias -a -e -m -l -x -f -o db2look.sql6.创建数据库db2 create db test17.生成定义db2 -tvf db2look.sql8.导入数据库所有的数据db2move db_alias import9.重组检查db2 reorgchk0.重组表tb1db2 reorg table tb11.更新统计信息db2 runstats on table tb12.备份数据库testdb2 backup db test3.恢复数据库testdb2 restore db test44.命令处理器参数列举可用命令格式:db2 list command options更改命令格式:update command options using option value(on/off)实例:比如更改命令行自动提交的参数2=>update command options using C off--或on,只是临时改变命令行下db2set db2options=+c --或-c,永久改变45. 获取当前机器db2所有配置信息:db2support . -d dbname -c此时数据库管理程序将生成一个db2support 压缩文件包。
1、打开命令行窗口#db2cmd2、打开控制中心# db2cmd db2cc3、打开命令编辑器db2cmd db2ce=====操作数据库命令=====4、启动数据库实例#db2start5、停止数据库实例#db2stop如果你不能停止数据库由于激活的连接,在运行db2stop前执行db2 force application all 就可以了/db2stop force6、创建数据库#db2 create db [dbname]7、连接到数据库#db2 connect to [dbname] user [username] using [password]8、断开数据库连接#db2 connect reset9、列出所有数据库#db2 list db directory10、列出所有激活的数据库#db2 list active databases11、列出所有数据库配置#db2 get dbcfg12、删除数据库#db2 drop database [dbname](执行此操作要小心)如果不能删除,断开所有数据库连接或者重启db2 =========操作数据表命令==========13、列出所有用户表#db2 list tables14、列出所有系统表#db2 list tables for system15、列出所有表#db2 list tables for all16、列出系统表#db2 list tables for system17、列出用户表#db2 list tables for user18、列出特定用户表#db2 list tables for schema [user]19、创建一个与数据库中某个表(t2)结构相同的新表(t1) #db2 create table t1 like t220、将一个表t1的数据导入到另一个表t2#db2 "insert into t1 select * from t2"21、查询表#db2 "select * from table name where ..."22、显示表结构#db2 describe table tablename23、修改列#db2 alter table [tablename] alter column [columname] set data type varchar(24)======脚本文件操作命令=======24、执行脚本文件#db2 -tvfscripts.sql25、帮助命令* 查看命令帮助#db2 ? db2start* 查看错误码信息#db2 ? 22001* memo: 详细命令请使用"db2 ? <command>"进行查看。
=========================26、备份数据库#db2 backup db<db name>备注:执行以上命令之前需要断开数据库连接27、在线备份数据库#db2 -v "BACKUP DATABASE <database name> ONLINE TO <path> WITH 2 BUFFERS BUFFER 1024 INCLUDE LOGS WITHOUT PROMPTING"28、恢复数据库#db2 restore db<source db name>29、在线恢复数据库#db2 "RESTORE DB <database name> TO <db path> LOGTARGET <logpath> WITHOUT PROMPTING"#db2 "ROLLFORWARD DB <database name> TO END OF LOGS AND STOP" ...30、导出数据文件#db2move <db name> export[-sn<模式名称,一般为db2admin>][-tn<表名,多个之间用逗号分隔>]31、导入数据文件#db2move <db name> import32、获取db2数据库管理配置环境信息#db2 get dbmcfg33、.获取db2某个数据库数据库管理配置环境信息#db2 get dbcfg for <db name>或者:连接至某个数据库以后执行db2 get dbcfg34、更改db2日志空间的大小备注:以下命令为了防止db2数据库过份使用硬盘空间而设,仅用于开发者自己机器上的db2,如果是服务器,则参数需要修改。
#db2 UPDATE DB CFG FOR <db name> USING logretain OFF logprimary 3 logsecond 2 logfilsiz 25600;如果页大小是4KB,则以上命令创建3个100M的日志文件,占用300MB硬盘空间。
25600*4KB=102400KB。
35、创建临时表空间#DB2 CREATE USER TEMPORARY TABLESPACE STMASPACE PAGESIZE 32 K MANAGED BY DATABASE USING (FILE 'D:\DB2_TAB\STMASPACE.F1' 10000)EXTENTSIZE 25636、获取数据库管理器的快照数据#db2 –v get snapshot for dbm37、显示进行程号#db2 list applications show detail===================================================一、加载数据:1、以默认分隔符加载,默认为“,”号db2 "import from btpoper.txt of del insert into btpoper"2、以指定分隔符“|”加载db2 "import from btpoper.txt of del modified by coldel| insert into btpoper"二、卸载数据:1、卸载一个表中全部数据db2 "export to btpoper.txt of del select * from btpoper"db2 "export to btpoper.txt of del modified by coldel| select * from btpoper"2、带条件卸载一个表中数据db2 "export to btpoper.txt of del select * from btpoper wherebrhid='907020000'"db2 "export to cmmcode.txt of del select * from cmmcode wherecodtp='01'"db2 "export to cmmcode.txt of del modified by coldel| select * from cmmcode where codtp='01'"三、查询数据结构及数据:db2 "select * from btpoper"db2 "select * from btpoper where brhid='907020000' andoprid='0001'"db2 "select oprid,oprnm,brhid,passwd from btpoper"四、删除表中数据:db2 "delete from btpoper"db2 "delete from btpoper where brhid='907020000' orbrhid='907010000'"五、修改表中数据:db2 "update svmmst set prtlines=0 where brhid='907010000' and jobtp='02'"db2 "update svmmst set prtlines=0 where jobtp='02' or jobtp='03'"六、联接数据库db2 connect to btpdbs七、清除数据库联接db2 connect reset 断开数据库连接db2 terminate 断开数据库连接db2 force applications all 断开所有数据库连接八、备份数据库1、db2 backup dbbtpdbs2、db2move btpdbs exportdb2look -d btpdbs -e -x [-a] -o crttbl.sql九、恢复数据库1、db2 restore dbbtpdbs without rolling forward2、db2 -tvfcrtdb.sqlcrtdb.sql文件内容:createdbbtpdbs on /db2catalogdb2 -stvfcrttbl.sqldb2movebtpdbs import十、DB2帮助命令:db2 ?db2 ?restroedb2 ?sqlcode (例:db2 ? sql0803) 注:code必须为4位数,不够4位,前面补0十一、bind命令:将应用程序与数据库作一捆绑,每次恢复数据库后,建议都要做一次bind(1) db2 bind br8200.bnd(2) /btp/bin/bndall /btp/bnd/btp/bin/bndall /btp/tran/bnd十二、查看数据库参数:db2 get dbmcfgdb2 get dbcfg for btpdbs十三、修改数据库参数:db2 update dbcfg for btpdbs using LOGBUFSZ 20db2 update dbcfg for btpdbs using LOGFILSIZ 5120改完后,应执行以下命令使其生效:db2 stopdb2 start补充:db2 set schema btp修改当前模式为"btp"db2 list tablespaces show detail 查看当前数据库表空间分配状况db2 list tablespace containers for 2 show detail 查看tablespace id=2使用容器所在目录db2 list applicationdb2 list db directory 列出所有数据库db2 list active databases 列出所有活动的数据库db2 list tables for all 列出当前数据库下所有的表db2 list tables for schema btp列出当前数据库中schema为btp的表db2 list tablespaces show detail 显示数据库空间使用情况db2 list packages for alldb2 "import from tab76.ixf of ixfcommitcount 5000 insert into achact"db2 "create table achact_t like achact"db2 "rename table achact_t to achact"db2 "insert into achact_t select * from achact where txndt>=(select lstpgdt fromacmact where actno=achact.actno)"db2 get snapshot for dynaimicsql on jining删除一个实例:# cd /usr/lpp/db2_07_01/instance# ./db2idrop InstName列出所有DB2实例:# cd /usr/lpp/db2_07_01/bin# ./db2ilist为数据库建立编目$ db2 catalog dbbtpdbs on /db2catalog取消已编目的数据库btpdbs$ db2 uncatalogdbbtpdbs查看版本# db2level显示当前数据库管理实例$ db2 get instance设置实例系统启动时是否自动启动。