首页
论坛
门户
空间
手机版
IXPUB
插件
收藏
设置
注册
登录
商店
搜索
培训
Wiki
Blog
归档
丛书
退出
ITPUB论坛
»
移动及嵌入式数据库
» 《SQL Anywhere Studio 9开发指南》代码
‹‹ 上一主题
|
下一主题 ››
55
5/6
‹‹
1
2
3
4
5
6
››
投票
交易
悬赏
活动
评价
|
打印
|
推荐
|
订阅
|
收藏
标题:
[参考文档]
《SQL Anywhere Studio 9开发指南》代码
ninetailsfox
老会员
精华贴数 0
个人空间
0
技术积分 2440 (644)
社区积分 0 (1542071)
注册日期 2007-9-5
论坛徽章:2
#41
使用道具
发表于 2007-11-27 08:18
5.4.1 Set DELETE [Top]
-----------------------------------------------------------------------------------
SELECT customer.id AS cust_id,
customer.company_name,
sales_order.id AS order_id,
sales_order.order_date,
employee.emp_id,
STRING ( employee.emp_fname, ' ', employee.emp_lname ) AS emp_name,
sales_order_items.line_id
FROM customer
INNER JOIN sales_order
ON sales_order.cust_id = customer.id
INNER JOIN employee
ON employee.emp_id = sales_order.sales_rep
INNER JOIN sales_order_items
ON sales_order_items.id = sales_order.id
WHERE STRING ( employee.emp_fname, ' ', employee.emp_lname )
IN ( 'Rollin Overbey', 'Philip Chin' )
AND customer.company_name
IN ( 'The Power Group', 'Darling Associates' )
AND sales_order.order_date <= '2000-12-31'
ORDER BY 1, 2, 3, 4, 5, 6, 7;
-----------------------------------------------------------------------------------
DELETE sales_order_items
FROM customer
INNER JOIN sales_order
ON sales_order.cust_id = customer.id
INNER JOIN employee
ON employee.emp_id = sales_order.sales_rep
INNER JOIN sales_order_items
ON sales_order_items.id = sales_order.id
WHERE STRING ( employee.emp_fname, ' ', employee.emp_lname )
IN ( 'Rollin Overbey', 'Philip Chin' )
AND customer.company_name
IN ( 'The Power Group', 'Darling Associates' )
AND sales_order.order_date <= '2000-12-31';
-----------------------------------------------------------------------------------
DELETE sales_order
FROM customer
INNER JOIN sales_order
ON sales_order.cust_id = customer.id
INNER JOIN employee
ON employee.emp_id = sales_order.sales_rep
WHERE STRING ( employee.emp_fname, ' ', employee.emp_lname )
IN ( 'Rollin Overbey', 'Philip Chin' )
AND customer.company_name
IN ( 'The Power Group', 'Darling Associates' )
AND sales_order.order_date <= '2000-12-31';
-----------------------------------------------------------------------------------
SELECT DISTINCT sales_order_items.*
FROM customer
INNER JOIN sales_order
ON sales_order.cust_id = customer.id
INNER JOIN employee
ON employee.emp_id = sales_order.sales_rep
INNER JOIN sales_order_items
ON sales_order_items.id = sales_order.id
WHERE STRING ( employee.emp_fname, ' ', employee.emp_lname )
IN ( 'Rollin Overbey', 'Philip Chin' )
AND customer.company_name
IN ( 'The Power Group', 'Darling Associates' )
AND sales_order.order_date <= '2000-12-31';
SELECT DISTINCT sales_order.*
FROM customer
INNER JOIN sales_order
ON sales_order.cust_id = customer.id
INNER JOIN employee
ON employee.emp_id = sales_order.sales_rep
INNER JOIN sales_order_items
ON sales_order_items.id = sales_order.id
WHERE STRING ( employee.emp_fname, ' ', employee.emp_lname )
IN ( 'Rollin Overbey', 'Philip Chin' )
AND customer.company_name
IN ( 'The Power Group', 'Darling Associates' )
AND sales_order.order_date <= '2000-12-31';
-----------------------------------------------------------------------------------
CREATE VIEW v_old_items AS
SELECT *
FROM sales_order_items
WHERE ship_date < DATEADD ( YEAR, -3, CURRENT DATE );
DELETE v_old_items
WHERE quantity <= 12;
-----------------------------------------------------------------------------------
只看该作者
ninetailsfox
老会员
精华贴数 0
个人空间
0
技术积分 2440 (644)
社区积分 0 (1542071)
注册日期 2007-9-5
论坛徽章:2
#42
使用道具
发表于 2007-11-27 08:18
5.5 DELETE WHERE CURRENT OF Cursor [Top]
-----------------------------------------------------------------------------------
CREATE TABLE t1 (
key_1 UNSIGNED INTEGER NOT NULL PRIMARY KEY,
non_key_1 INTEGER NOT NULL );
INSERT t1 VALUES ( 1, 1 );
INSERT t1 VALUES ( 2, 2 );
INSERT t1 VALUES ( 3, 3 );
INSERT t1 VALUES ( 4, 4 );
INSERT t1 VALUES ( 5, 5 );
BEGIN
DECLARE @t1_key_1 INTEGER;
DECLARE @t1_non_key_1 INTEGER;
DECLARE @SQLSTATE VARCHAR ( 5 );
DECLARE cloop1 CURSOR FOR
SELECT t1.key_1,
t1.non_key_1
FROM t1
CROSS JOIN t1 AS x
WHERE t1.key_1 = 2;
OPEN cloop1;
FETCH cloop1 INTO
@t1_key_1,
@t1_non_key_1;
SET @SQLSTATE = SQLSTATE;
WHILE ( @SQLSTATE = '00000' ) LOOP
DELETE t1
WHERE CURRENT OF cloop1;
FETCH cloop1 INTO
@t1_key_1,
@t1_non_key_1;
SET @SQLSTATE = SQLSTATE;
END LOOP;
CLOSE cloop1;
END;
-----------------------------------------------------------------------------------
只看该作者
ninetailsfox
老会员
精华贴数 0
个人空间
0
技术积分 2440 (644)
社区积分 0 (1542071)
注册日期 2007-9-5
论坛徽章:2
#43
使用道具
发表于 2007-11-27 08:18
5.6 TRUNCATE TABLE [Top]
-----------------------------------------------------------------------------------
CREATE TABLE t1 (
key_1 UNSIGNED INTEGER NOT NULL PRIMARY KEY,
non_key_1 INTEGER NOT NULL );
CREATE TABLE t2 (
key_1 UNSIGNED INTEGER NOT NULL PRIMARY KEY,
non_key_1 INTEGER NOT NULL );
INSERT t1 VALUES ( 1, 1 );
INSERT t2 VALUES ( 22, 22 );
COMMIT;
-----------------------------------------------------------------------------------
SET EXISTING OPTION PUBLIC.TRUNCATE_WITH_AUTO_COMMIT = 'ON';
UPDATE t2 SET non_key_1 = 999;
TRUNCATE TABLE t1;
ROLLBACK;
-----------------------------------------------------------------------------------
SET EXISTING OPTION PUBLIC.TRUNCATE_WITH_AUTO_COMMIT = 'OFF';
UPDATE t2 SET non_key_1 = 999;
TRUNCATE TABLE t1;
ROLLBACK;
-----------------------------------------------------------------------------------
CREATE TABLE t1 (
key_1 INTEGER NOT NULL PRIMARY KEY,
inserted_date DATE NOT NULL DEFAULT CURRENT DATE,
blob LONG VARCHAR );
-----------------------------------------------------------------------------------
DELETE t1
WHERE inserted_date < DATEADD ( DAY, -7, CURRENT DATE );
-----------------------------------------------------------------------------------
SELECT *
INTO #t1
FROM t1
WHERE inserted_date >= DATEADD ( DAY, -7, CURRENT DATE );
TRUNCATE TABLE t1;
INSERT t1
SELECT *
FROM #t1;
-----------------------------------------------------------------------------------
只看该作者
ninetailsfox
老会员
精华贴数 0
个人空间
0
技术积分 2440 (644)
社区积分 0 (1542071)
注册日期 2007-9-5
论坛徽章:2
#44
使用道具
发表于 2007-11-27 08:18
5.7 Chapter Summary [Top]
-----------------------------------------------------------------------------------
Chapter 6 - FETCHING [Top]
-----------------------------------------------------------------------------------
6.1 Introduction [Top]
-----------------------------------------------------------------------------------
6.2 Cursor FETCH Loop [Top]
-----------------------------------------------------------------------------------
BEGIN
DECLARE @key_1 INTEGER;
DECLARE @non_key_1 VARCHAR ( 100 );
DECLARE @last_updated TIMESTAMP;
DECLARE @SQLSTATE VARCHAR ( 5 );
DECLARE @loop_counter INTEGER;
DECLARE c_fetch NO SCROLL CURSOR FOR
SELECT TOP 1000
t1.key_1,
t1.non_key_1,
t1.last_updated
FROM t1
WHERE t1.last_updated < DATEADD ( MONTH, -6, CURRENT DATE )
ORDER BY t1.last_updated
FOR UPDATE;
OPEN c_fetch WITH HOLD;
FETCH c_fetch INTO
@key_1,
@non_key_1,
@last_updated;
SET @SQLSTATE = SQLSTATE;
SET @loop_counter = 0;
WHILE @SQLSTATE = '00000' LOOP
SET @loop_counter = @loop_counter + 1;
MESSAGE STRING ( 'Deleting ',
@loop_counter, ', ',
@key_1, ', "',
@non_key_1, '", ',
@last_updated ) TO CONSOLE;
DELETE t1 WHERE CURRENT OF c_fetch;
IF MOD ( @loop_counter, 100 ) = 0 THEN
COMMIT;
MESSAGE STRING ( 'COMMIT after ', @loop_counter, ' rows.' ) TO CONSOLE;
END IF;
FETCH c_fetch INTO
@key_1,
@non_key_1,
@last_updated;
SET @SQLSTATE = SQLSTATE;
END LOOP;
CLOSE c_fetch;
COMMIT;
MESSAGE STRING ( 'Final COMMIT after ', @loop_counter, ' rows.' ) TO CONSOLE;
END;
-----------------------------------------------------------------------------------
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include "sqldef.h"
EXEC SQL INCLUDE SQLCA;
int main() {
EXEC SQL BEGIN DECLARE SECTION;
long key_1;
char non_key_1 [ 101 ];
char last_updated [ 24 ];
EXEC SQL END DECLARE SECTION;
char copy_SQLSTATE [ 6 ];
long loop_counter;
ldiv_t loop_counter_ldiv;
db_init( &sqlca );
EXEC SQL CONNECT USING 'ENG=test6;DBN=test6;UID=DBA;PWD=SQL';
EXEC SQL DECLARE c_fetch NO SCROLL CURSOR FOR
SELECT TOP 1000
t1.key_1,
t1.non_key_1,
DATEFORMAT ( t1.last_updated, 'yyyy-mm-dd hh:nn:ss.sss' )
FROM t1
WHERE t1.last_updated < DATEADD ( MONTH, -6, CURRENT DATE )
ORDER BY t1.last_updated
FOR UPDATE;
EXEC SQL OPEN c_fetch WITH HOLD;
EXEC SQL FETCH c_fetch INTO
:key_1,
:non_key_1,
:last_updated;
strcpy ( copy_SQLSTATE, SQLSTATE );
loop_counter = 0;
while ( strcmp ( copy_SQLSTATE, "00000" ) == 0 ) {
loop_counter = loop_counter + 1;
printf ( "Deleting %d, %d, '%s', %s\n",
loop_counter,
key_1,
non_key_1,
last_updated );
EXEC SQL DELETE t1 WHERE CURRENT OF c_fetch;
loop_counter_ldiv = ldiv ( loop_counter, 100L );
if ( loop_counter_ldiv.rem == 0 ) {
EXEC SQL COMMIT;
printf ( "COMMIT after %d rows.\n", loop_counter );
}
EXEC SQL FETCH c_fetch INTO
:key_1,
:non_key_1,
:last_updated;
strcpy ( copy_SQLSTATE, SQLSTATE );
} // while...
EXEC SQL CLOSE c_fetch;
EXEC SQL COMMIT;
EXEC SQL DISCONNECT;
db_fini ( &sqlca );
printf ( "Done after %d rows.\n", loop_counter );
return ( 0 );
} // main
-----------------------------------------------------------------------------------
只看该作者
ninetailsfox
老会员
精华贴数 0
个人空间
0
技术积分 2440 (644)
社区积分 0 (1542071)
注册日期 2007-9-5
论坛徽章:2
#45
使用道具
发表于 2007-11-27 08:18
6.2.1 DECLARE CURSOR FOR Select [Top]
-----------------------------------------------------------------------------------
CREATE PROCEDURE p_delete_oldest ( IN @age_in_months INTEGER )
BEGIN
DECLARE @key_1 INTEGER;
DECLARE @non_key_1 VARCHAR ( 100 );
DECLARE @last_updated TIMESTAMP;
DECLARE @SQLSTATE VARCHAR ( 5 );
DECLARE @loop_counter INTEGER;
DECLARE c_fetch NO SCROLL CURSOR FOR
SELECT TOP 1000
t1.key_1,
t1.non_key_1,
t1.last_updated
FROM t1
WHERE t1.last_updated < DATEADD ( MONTH, -@age_in_months, CURRENT DATE )
ORDER BY t1.last_updated
FOR UPDATE;
OPEN c_fetch WITH HOLD;
FETCH c_fetch INTO
@key_1,
@non_key_1,
@last_updated;
SET @SQLSTATE = SQLSTATE;
SET @loop_counter = 0;
WHILE @SQLSTATE = '00000' LOOP
SET @loop_counter = @loop_counter + 1;
DELETE t1 WHERE CURRENT OF c_fetch;
IF MOD ( @loop_counter, 100 ) = 0 THEN
COMMIT;
END IF;
FETCH c_fetch INTO
@key_1,
@non_key_1,
@last_updated;
SET @SQLSTATE = SQLSTATE;
END LOOP;
CLOSE c_fetch;
COMMIT;
END; -- p_delete_oldest
CALL p_delete_oldest ( 6 );
-----------------------------------------------------------------------------------
BEGIN
DECLARE @level INTEGER;
DECLARE @name VARCHAR ( 20 );
DECLARE @SQLSTATE VARCHAR ( 5 );
DECLARE @loop_counter INTEGER;
DECLARE c_fetch NO SCROLL CURSOR FOR
WITH RECURSIVE superior_list
( level,
chosen_employee_id,
manager_id,
employee_id,
name )
AS ( SELECT CAST ( 1 AS INTEGER ) AS level,
employee.employee_id AS chosen_employee_id,
employee.manager_id AS manager_id,
employee.employee_id AS employee_id,
employee.name AS name
FROM employee
UNION ALL
SELECT superior_list.level + 1,
superior_list.chosen_employee_id,
employee.manager_id,
employee.employee_id,
employee.name
FROM superior_list
INNER JOIN employee
ON employee.employee_id = superior_list.manager_id
WHERE superior_list.level <= 99
AND superior_list.manager_id <> superior_list.employee_id )
SELECT superior_list.level,
superior_list.name
FROM superior_list
WHERE superior_list.chosen_employee_id = 13
ORDER BY superior_list.level DESC
FOR READ ONLY;
OPEN c_fetch WITH HOLD;
FETCH c_fetch INTO
@level,
@name;
SET @SQLSTATE = SQLSTATE;
SET @loop_counter = 0;
WHILE @SQLSTATE = '00000' LOOP
SET @loop_counter = @loop_counter + 1;
MESSAGE STRING ( @level, ' ', @name ) TO CONSOLE;
FETCH c_fetch INTO
@level,
@name;
SET @SQLSTATE = SQLSTATE;
END LOOP;
CLOSE c_fetch;
END;
-----------------------------------------------------------------------------------
只看该作者
ninetailsfox
老会员
精华贴数 0
个人空间
0
技术积分 2440 (644)
社区积分 0 (1542071)
注册日期 2007-9-5
论坛徽章:2
#46
使用道具
发表于 2007-11-27 08:19
6.2.2 DECLARE CURSOR USING Select [Top]
-----------------------------------------------------------------------------------
BEGIN -- outer block
DECLARE @select LONG VARCHAR;
SET @select = '
SELECT TOP 1000
t1.key_1,
t1.non_key_1,
t1.last_updated
FROM t1
WHERE t1.last_updated < DATEADD ( MONTH, -6, CURRENT DATE )
ORDER BY t1.last_updated
FOR UPDATE';
BEGIN -- inner block
DECLARE @key_1 INTEGER;
DECLARE @non_key_1 VARCHAR ( 100 );
DECLARE @last_updated TIMESTAMP;
DECLARE @SQLSTATE VARCHAR ( 5 );
DECLARE @loop_counter INTEGER;
DECLARE c_fetch NO SCROLL CURSOR USING @select;
OPEN c_fetch WITH HOLD;
FETCH c_fetch INTO
@key_1,
@non_key_1,
@last_updated;
SET @SQLSTATE = SQLSTATE;
SET @loop_counter = 0;
WHILE @SQLSTATE = '00000' LOOP
SET @loop_counter = @loop_counter + 1;
DELETE t1 WHERE CURRENT OF c_fetch;
IF MOD ( @loop_counter, 100 ) = 0 THEN
COMMIT;
MESSAGE STRING ( 'COMMIT after ', @loop_counter, ' rows.' ) TO CONSOLE;
END IF;
FETCH c_fetch INTO
@key_1,
@non_key_1,
@last_updated;
SET @SQLSTATE = SQLSTATE;
END LOOP;
CLOSE c_fetch;
COMMIT;
END; -- inner block
END; -- outer block
-----------------------------------------------------------------------------------
只看该作者
ninetailsfox
老会员
精华贴数 0
个人空间
0
技术积分 2440 (644)
社区积分 0 (1542071)
注册日期 2007-9-5
论坛徽章:2
#47
使用道具
发表于 2007-11-27 08:19
6.2.3 DECLARE CURSOR FOR CALL [Top]
-----------------------------------------------------------------------------------
CREATE PROCEDURE p_oldest ( IN @age_in_months INTEGER )
BEGIN
SELECT TOP 1000
t1.key_1,
t1.non_key_1,
t1.last_updated
FROM t1
WHERE t1.last_updated < DATEADD ( MONTH, -@age_in_months, CURRENT DATE )
ORDER BY t1.last_updated;
END;
BEGIN
DECLARE @key_1 INTEGER;
DECLARE @non_key_1 VARCHAR ( 100 );
DECLARE @last_updated TIMESTAMP;
DECLARE @SQLSTATE VARCHAR ( 5 );
DECLARE @loop_counter INTEGER;
DECLARE c_fetch NO SCROLL CURSOR FOR CALL p_oldest ( 6 );
OPEN c_fetch WITH HOLD;
FETCH c_fetch INTO
@key_1,
@non_key_1,
@last_updated;
SET @SQLSTATE = SQLSTATE;
SET @loop_counter = 0;
WHILE @SQLSTATE = '00000' LOOP
SET @loop_counter = @loop_counter + 1;
DELETE t1
WHERE t1.key_1 = @key_1;
IF MOD ( @loop_counter, 100 ) = 0 THEN
COMMIT;
END IF;
FETCH c_fetch INTO
@key_1,
@non_key_1,
@last_updated;
SET @SQLSTATE = SQLSTATE;
END LOOP;
CLOSE c_fetch;
COMMIT;
END;
-----------------------------------------------------------------------------------
只看该作者
ninetailsfox
老会员
精华贴数 0
个人空间
0
技术积分 2440 (644)
社区积分 0 (1542071)
注册日期 2007-9-5
论坛徽章:2
#48
使用道具
发表于 2007-11-27 08:20
6.2.4 OPEN and CLOSE Cursor [Top]
-----------------------------------------------------------------------------------
OPEN c_fetch WITH HOLD;
IF SQLSTATE <> '00000' THEN
RAISERROR 20000 STRING ( 'Cursor OPEN SQLSTATE = ', SQLSTATE )
END IF;
-----------------------------------------------------------------------------------
6.2.5 FETCH Cursor [Top]
-----------------------------------------------------------------------------------
6.3 Cursor FOR Loop [Top]
-----------------------------------------------------------------------------------
BEGIN
DECLARE @loop_counter INTEGER;
SET @loop_counter = 0;
FOR f_fetch
AS c_fetch NO SCROLL CURSOR FOR
SELECT TOP 1000
t1.key_1 AS @key_1,
t1.non_key_1 AS @non_key_1,
t1.last_updated AS @last_updated
FROM t1
WHERE t1.last_updated < DATEADD ( MONTH, -6, CURRENT DATE )
ORDER BY t1.last_updated
FOR UPDATE
DO
SET @loop_counter = @loop_counter + 1;
MESSAGE STRING ( 'Deleting ',
@loop_counter, ', ',
@key_1, ', "',
@non_key_1, '", ',
@last_updated ) TO CONSOLE;
DELETE t1 WHERE CURRENT OF c_fetch;
IF MOD ( @loop_counter, 100 ) = 0 THEN
COMMIT;
END IF;
END FOR;
COMMIT;
END;
-----------------------------------------------------------------------------------
CREATE PROCEDURE p_oldest ( IN @age_in_months INTEGER )
BEGIN
SELECT TOP 1000
t1.key_1 AS @key_1,
t1.non_key_1 AS @non_key_1,
t1.last_updated AS @last_updated
FROM t1
WHERE t1.last_updated < DATEADD ( MONTH, -@age_in_months, CURRENT DATE )
ORDER BY t1.last_updated;
END;
BEGIN
DECLARE @loop_counter INTEGER;
SET @loop_counter = 0;
FOR f_fetch
AS c_fetch NO SCROLL CURSOR FOR CALL p_oldest ( 6 )
DO
SET @loop_counter = @loop_counter + 1;
MESSAGE STRING ( 'Deleting ',
@loop_counter, ', ',
@key_1, ', "',
@non_key_1, '", ',
@last_updated ) TO CONSOLE;
DELETE t1
WHERE t1.key_1 = @key_1;
IF MOD ( @loop_counter, 100 ) = 0 THEN
COMMIT;
END IF;
END FOR;
COMMIT;
END;
-----------------------------------------------------------------------------------
只看该作者
ninetailsfox
老会员
精华贴数 0
个人空间
0
技术积分 2440 (644)
社区积分 0 (1542071)
注册日期 2007-9-5
论坛徽章:2
#49
使用道具
发表于 2007-11-27 08:20
6.4 Chapter Summary [Top]
-----------------------------------------------------------------------------------
CHAPTER 7 - SYNCHRONIZING [Top]
-----------------------------------------------------------------------------------
7.1 Introduction [Top]
-----------------------------------------------------------------------------------
7.2 How MobiLink Works [Top]
-----------------------------------------------------------------------------------
7.3 The MobiLink ASA Client [Top]
-----------------------------------------------------------------------------------
7.4 MobiLink Client Setup [Top]
-----------------------------------------------------------------------------------
7.4.1 CREATE PUBLICATION [Top]
-----------------------------------------------------------------------------------
CREATE PUBLICATION p1 (
TABLE t1 ( key_1,
key_2,
non_key_1,
non_key_2 ),
TABLE t2 ( key_1,
non_key_1 ) );
-----------------------------------------------------------------------------------
7.4.2 CREATE SYNCHRONIZATION USER [Top]
-----------------------------------------------------------------------------------
CREATE SYNCHRONIZATION USER "1"
TYPE tcpip
ADDRESS 'host=mobilink.risingroad.com'
OPTION ConflictRetries='2';
-----------------------------------------------------------------------------------
只看该作者
ninetailsfox
老会员
精华贴数 0
个人空间
0
技术积分 2440 (644)
社区积分 0 (1542071)
注册日期 2007-9-5
论坛徽章:2
#50
使用道具
发表于 2007-11-27 08:20
7.4.3 CREATE SYNCHRONIZATION SUBSCRIPTION [Top]
-----------------------------------------------------------------------------------
CREATE SYNCHRONIZATION SUBSCRIPTION TO p1 FOR "1"
TYPE tcpip
ADDRESS 'port=2439'
OPTION LockTables='OFF',
FireTriggers='ON',
SendTriggers='ON',
ScriptVersion='1',
SendDownloadACK='ON';
-----------------------------------------------------------------------------------
只看该作者
55
5/6
‹‹
1
2
3
4
5
6
››
投票
交易
悬赏
活动
相关内容
ITPUB论坛
≡ 数据库技术 ≡
> Oracle数据库管理
> Oracle开发
> Oracle Developer Suite
> Oracle入门与认证
> Oracle专题深入讨论
> Oracle新技术/11g
> Oracle电子文档
> Oracle Application Server套件
> IBM数据库产品
> MS SQL Server
> Sybase管理与开发
> MySQL及其它开源数据库
> 内存数据库
> 数据仓库与数据挖掘
> 移动及嵌入式数据库
≡ 企业信息化 ≡
> ERP产品与实践
> CRM产品与实践
> HR产品与实践
> 物流
> 供应链
> 供应链建模与仿真
> 物流设备与系统工程
> 企业管理咨询
> 管理协同与办公自动化
> IT服务管理
> 数据中心建设
> ERP二次开发
> Oracle ERP
> EBS相关文档
> PeopleSoft与JDE
> SAP R/3
> SAP Business One开发与快速实施
> SAP财务及CRM
> SAP后勤及HR
> mySAP ERP
> 系统开发及跨应用设置
> SAP相关文档
> 国外其它ERP产品
> 国内ERP产品
≡ 开发技术 ≡
> Java入门与认证版
> Java web开发及框架技术
> Java企业开发
> ASP.NET【已迁移到微软开发技术论坛】
> .Net企业开发与应用【已迁移到微软开发技术论坛】
> WEB程序开发
> WEB 2.0技术
> 动态语言
> 移动与游戏开发
≡ 系统设计与项目管理 ≡
> 系统分析与UML
> 系统分析与UML精华区
> 项目管理
> 项目过程
> 软件测试
> 算法讨论与研究
≡ IBM软件技术园地 ≡
> IBM数据库产品
> Lotus
> Tivoli
> Websphere
> Rational
> 与SOA相关的IBM产品与技术
> IBM软件技术精英协会
> 软件技术精英活动专版
≡ 操作系统与硬件 ≡
> AIX及IBM产品【已迁移到IXPUB】
> HP-UX及HP产品【已迁移到IXPUB】
> Solaris及SUN产品【已迁移到IXPUB】
> Linux及其应用 【已迁移到IXPUB】
> 其它UNIX系统【已迁移到IXPUB】
> windows系统及微软相关产品 【已迁移到IXPUB】
> 存储设备与容灾技术 【已迁移到IXPUB】
> 服务器 【已迁移到IXPUB】
≡ 行业纵向讨论区 ≡
> IT业界评论与展望
> 政府与教育事业
> 中国政府信息主管联盟
> 电信行业
> 金融行业
> 医卫行业
> 制造行业
> 电力行业
> 信息安全与审计
≡ 会员交流 ≡
> IT职业生涯
> 招聘求职商务信息
> 体育世界
> 体育博彩专版
> 旅游,驴友
> 汽车世界
> 外语角
> 数码摄影
> 你的故事我的歌
> 音乐推荐区
> 电子图书与IT文档资料
> 软件交流
> 软件交流精华区
≡ ITPUB产品与服务 ≡
> ITPUB地面活动专版
> BLOG天地
> WIKI世界
> 授权用户区
> 站务管理
≡ 微软开发技术 ≡
> 开发工具和语言
> .NET Framework 相关
> Visual Basic/VB.net
> Visual C#
> Visual C++/vc.net
> Visual Studio
> .NET软件架构与模式
> .NET开发辅助工具及框架
> Web开发
> ASP.NET与AJAX
> Web相关技术讨论(IIS等)
> Silverlight 技术
> 微软企业级产品技术
> SQL Server
> windows server
> SharePoint
> Exchange Server
> Biztalk
> 嵌入式及移动开发
> Windows Embedded 嵌入式技术
> Windows 移动设备
> Office开发
> Microsoft office system
> Office Business Application
> 微软产品用户交流区
> .Net电子书籍&&书籍介绍
> .Net人才交流
技术积分榜
社区积分榜
徽章
电子杂志
会员
团队
统计
邮箱
游乐场
帮助
TOP
CopyRight 1999-2006 itpub.net All Right Reserved.
北京皓辰广域网络信息技术有限公司. 版权所有
E-mail:Webmaster@itpub.net
京ICP证:010037号
联系我们
法律顾问
控制面板首页
编辑个人资料
积分交易
公众用户组
好友列表
升级个人空间
基本概况
论坛排行
主题排行
发帖排行
积分排行
在线时间
管理团队
管理统计