API的概括 

  X5.database 
2.1.1 X5.database.X5Persist类的描述    X5db为数据库支持,提供创建数据库、创建表、创建视图、创建存储过程等一些DDL的操作,以及对数据库表的增删查改操作。 X5.database包下,有X5Persist 、 X5dbprocSupport 、 X5DBResult 三个类。 2.1.1.1 X5.database.X5Persist类 
该类用来做数据库的所有操作,X5提供两种方式(下面有具体说明)来得到该类的实例对象。X5Persist的方法介绍: 2.1.1.2 X5.database.X5DBResult类 
该类为查询数据库得到的结果集,X5DBResult的方法介绍: 
2.1.1.3 X5.database.X5dbprocSupport类 
该类X5DB为支持存储过程的一个辅助类,执行前用于封装存储过程的参数定义,执行后用于封装存储过程的返回结果。 X5dbprocSupport的方法介绍: 
  X5.file 
2.2.1 X5.file类的描述    X5file为文件系统支持,提供文件夹和文件的创建、重命名、删除、读取和写入操作、X5.file包下,有X5File 、X5FileResult 两个类。 2.2.1.1 X5.file.X5File类 
该类用来对文件的所有操作,X5提供两种方式(下面有具体说明)来得到该类的实例对象。X5File的方法介绍: 
2.2.1.1X5.file.X5FileResult类 
该类用来封装查看文件夹下的文件信息X5FileResult的方法介绍: 
  X5.Exception 
2.3.1 X5.Exception类的描述    X5EXception为公共的异常类,做本APIs中可能抛出的异常都可以通过该异常类处理。X5.exception包下,有X5EXception 一个类。 2.3.1.1 X5.exception.X5Exception类 
该类为异常类,抛出该异常后通过异常码和异常信息以及异常的堆栈信息可以帮助我们更快的找出程序错误。 
异常码说明: 
400 用户账号异常,账号或者密码错误,或被禁用 
500 socket通信错误,接收响应数据失败 
501 socket通信错误,发送请求数据失败 
502 socket通信错误,发送请求数据失败 
503 socket通信错误,发送请求数据失败 
600 socket通信错误,接收请求数据失败 
601 socket通信错误,接收请求数据失败 
602 socket通信错误,接收请求数据失败 
700 无法连接数据库,可能数据库名错误或数据库类型指定错误 
701 数据库重名了 
702 工作单元批处理错误 
703 工作单元事务回滚错误 
704 查询数据库表错误 
705 数据库的增删改错误或者DDL操作失败 
706 创建数据库失败 
707 执行存储过程失败 
800 用户文件系统根路径无效 
801 创建文件夹失败,可能该文件夹已经存在 
802 新建文件失败,可能该文件已经存在 
803 重命名文件失败,可能文件不存在,或者已经存在要重命名的文件 
804 删除文件失败,可能文件不存在,或者文件夹不为空 
805 查看文件失败,可能文件不存在,或者无法查看此文件 
806 查看文件长度失败,可能文件不存在 
807 读取文件失败,可能文件不存在或者指定了文件夹 
808 写入文件失败,可能无法创建此文件 
以上错误码说明仅供参考,详细信息可调用getMessage()方法查看。 
X5_SDK用法举例 
  X5DB对数据库的操作 
首先实例化一个X5persist对象: 
X5Persist X5 = new X5Persist(); 
(String userid,int dbtype,int dbname,String serverip); 
参数:Userid由运营商提供 
Dbtype为数据库类型,见相关约定 
Dbtype为数据库名字,用户自取 
Serverip由运营商提供 
我们只需提供上述四个参数,构造一个X5Persist的实例,就可以做所有对数据库的操作了。实例中提供的方法,下面以例子的形式逐一介绍其用法。方法的具体定义,参考相应的JAVADOC即有详细说明。 
第一步,我们来创建一个数据库1. public static void main(String[] args) {
 
2. String userid="1241234544445412"; //userid 
3. int dbtype=2; //dbtype 
4. String dbname="qishima"; //dbname 
5. String serverip="service.x5cloud.com"; //serverip 
6. //实例化,把标志身份的userid传过去 
7. X5Persist x5=new X5Persist(userid,dbtype,dbname,serverip); 
10. int count=-1; 
11. try {
 
12. //调用方法,返回int值大于或等于零为创库成功 
13. count=x5.createDB(); 
14. } catch (X5Exception e) {
 
15. e.printStackTrace(); 
16. System.out.println(e.getMessage()); 
17. } 
18. if(count>=0){
 
19. System.out.println("创建数据库成功"); 
20. } 
代码13行调用了x5persist.createDB()方法创建数据库。 
第二步,我们在数据库中创建一张表1. public static void main(String[] args) {
 
2. //创建sqlserver表的sql语句 
3. String sql="create table UserInfo123" + 
4. "(user_id int not null," + 
5. "user_name varchar(20) not null," + 
6. "user_sex char(2) default('男')," + 
7. "user_age int default(18)" + 
8. ")"; 
9. String userid="1241234544445412"; //userid 
10. int dbtype=2; //dbtype 
11. String dbname="qishima"; //dbname 
12. String serverip="service.x5cloud.com"; //serverip 
13. //实例化,把标志身份的userid传过去 
14. X5Persist x5=new X5Persist(userid,dbtype,dbname,serverip); 
15. int count=-1; 
16. try {
 
17. //调用方法,返回int值大于或等于零为创建表成功 
18. count = x5.persist(sql); 
19. } catch (X5Exception e) {
 
20. System.out.println(e.getMessage()); 
21. e.printStackTrace(); 
22. } 
23. if(count>=0){
 
24. System.out.println("成功!受影响行数为:"+count); 
25. } 
26. } 
代码18行调用了x5persist的persist(String sql)方法,该方法可以做几乎除创库和查询外的所有数据库操作,该方法也有一个重载的方法persist(String sql,Object[] objs),重载的方法支持了sql语句的参数列表。 
第三步,我们在新建的数据库表中做增删改操作,这里我们通过一个工作单元来完成这三类动作。实际上我们也可以通过单独调用X5.persist (String sql) 方法,来分步做增删改。这里X5.X5job()方法为一个job单元,我们可以通过设置istransaction的值(0为false,1为true)来做事务支持。1. public static void main(String[] args) {
 
2. String str1="insert into UserInfo123 values('张三',default,default)"; 
3. String str2="insert into UserInfo123 values('李四','女',20)"; 
4. String str3="update UserInfo123 set user_name='王五',user_age=30 where user_name='张三'"; 
5. String str4="delete from UserInfo123 where user_name='李四'"; 
6. List<String> sql=new ArrayList<String>(); 
7. sql.add(str1); 
8. sql.add(str2); 
9. sql.add(str3); 
10. sql.add(str4); 
11. int istransaction=1; 
12. String userid="1241234544445412"; //userid 
13. int dbtype=2; //dbtype 
14. String dbname="qishima"; //dbname 
15. String serverip="service.x5cloud.com"; //serverip 
16. //实例化,把标志身份的userid传过去 17. X5Persist x5=new X5Persist(userid,dbtype,dbname,serverip); 
18. boolean flag=false; 
19. try {
 
20. //调用方法,返回boolean值标识是否执行成功 
21. flag = x5.x5job(sql,istransaction); 
22. } catch (X5Exception e) {
 
23. System.out.println(e.getMessage()); 
24. e.printStackTrace(); 
25. } 
26. if(flag){
 
27. System.out.println("成功!"); 
28. } 
29. } 
代码2至10行,把要执行的增删改sql语句放入一个list集合中,代码21行调用方法x5job(List<String> sql),第二个参数可以标识是否为这个job工程添加事务支持,可以缺省,缺省时为不添加事务。 
第四步,我们来个简单查询表,数据调用select()方法后,返回的是一个X5DBResult对象,从该对象中取数据同JDBC中的ResultSet,略有不同,详见对X5DBResult类的介绍。1. public static void main(String[] args) {
 
2. String sql="select * from UserInfo where user_id<?"; 
3. Object []objs=new Object[]{1000}; 
4. String userid="1241234544445412"; //userid 
5. int dbtype=2; //dbtype 
6. String dbname="qishima"; //dbname 
7. String serverip="service.x5cloud.com"; //serverip 
8. //实例化,把标志身份的userid传过去 
9. X5Persist x5=new X5Persist(userid,dbtype,dbname,serverip); 
10. try {
 
11. X5DBResult set=x5.select(sql,objs); 
12. List<Object> columns=set.getColumns(); 
13. for(Object obj:columns){
 
14. System.out.print(obj.toString()+" "); 
15. } 
16. System.out.println(""); 
17. while(set.hasNext()){
 
18. System.out.println(set.getObject("user_id")+""+set.getObject("user_name")+""+set.getObject(3)+""+set.getObject(4));
19. } 
20. } catch (X5Exception e) {
 
21. e.printStackTrace(); 
22. } 
23. } 
本例子是做一个简单的条件查询,见代码2至3行。代码11行调用了select(String sql,Object[] objs)方法,返回一个X5DBResult的实例对象,该实例对象封装着查询结果,代码12至19是访问的查询结果。 
代码12行调用getColmns()方法,得到结果集的表头信息,13至15采用for循环遍历打印表头的列名。 
代码17至19为取数据,先是hasNext()判断结果集中是否有下一行数据。 
代码18行中,通过getObject(String columnName)或者getObject(int columnsIndex)来取出当前指针指向的一行记录中的值。注意columnName必须和数据库字段名一致,需要严格注意大小写。 
这样我们就从查询返回的结果集中取出了我们想要的数据,是不是跟JDBC中的ResultSet极为相似呢?还有一些getSize()获得结果集大小等方法,可以参见javadoc 
第五步,我们来尝试执行一个存储过程。为了说明问题,我们选择执行一个带IN参,OUT参和查询结果集的存储过程,这一步我们需要借助一个辅助类X5dbprocSupport,用法同JDBC的CallableStatement,略有不同,详见X5dbprocSupport类的介绍