J2ME学习笔记(二)

发表于:2007-07-01来源:作者:点击数: 标签:
这个是帮同学写的一个十分十分简单的一个例子,因为我手头没有移动设备,而且那个时候还不会用什么模拟器。。,所以就在本级调试成功就没有管了。 数据库 是用的 SQL Anywhere,感觉这个还不错。因为以前也没有研究过,所以就觉得这东西方便。在下就不买瓜再
这个是帮同学写的一个十分十分简单的一个例子,因为我手头没有移动设备,而且那个时候还不会用什么模拟器。。,所以就在本级调试成功就没有管了。数据库是用的SQL Anywhere,感觉这个还不错。因为以前也没有研究过,所以就觉得这东西方便。在下就不买瓜再次把SQL Anywhere怎么用详细讲了,我也是下了它的中文文档来研究的。如果那位仁兄想偷懒不想自己找就加我的sans_reason@hotmail.com 我发给你好了。呵呵


/*
* 如果部署到WindowsCE设备上把jul9.dll和jul9_zh.jar自己拷贝过去
* 设备应该安装Djeode
* 建立test.lnk
*18#"\存储卡\Insignia Solutions JeodeRuntime\evm.exe"
*-Djeode.evm.console.local.keep=TRUE
*-Djeode.evm.console.local.paging=TRUE
*-Djul.library.dir=\UltraLite\lib
*-cp \UltraLite\tutorial;\UltraLite\lib\jul9_zh.jar
*Customer
*/
/**
* @author LiYou
*
*
*/
import ianywhere.native_ultralite.*;
import java.sql.SQLException;
public class Customer{
static Connection conn;
public static void main( String args[]){
try{
Customer cust = new Customer();
cust.insert();
cust.select();
conn.close();
}catch( SQLException e){
e.printStackTrace();
}
}
public Customer() throws SQLException{
DatabaseManager dbMgr = new DatabaseManager();
/*
* UltraLite默认滴数据库用户名和密码。。。怎么改不知道,偶不会这个东西也没有研究
*/
String parms = "uid=DBA"
+ ";pwd=SQL"
+ ";file_name=f:\\j2me\\tutcustomer.udb"
+ ";schema_file=f:\\j2me\\tutcustomer.usm"
+ ";ce_file=\\UltraLite\\tutorial\\tutcustomer.udb"
+ ";ce_schema=\\UltraLite\\tutorial\\tutcustomer.usm";
/*
* 如果部署到WindowsCE设备上把这行添加两条
* ce_file=\\UltraLite\\tutorial\\tutcustomer.udb
* ce_schema=\\UltraLite\\tutorial\\tutcustomer.usm
*
* 在桌面应该系统中这两行没有效果滴!自己注意!
*/
try {
conn = dbMgr.openConnection( parms );
System.out.println(
"连接到数据库tutcustomer!" );
}catch( SQLException econn ){
if(econn.getErrorCode()==SQLCode.SQLE_ULTRALITE_DATABASE_NOT_FOUND){
//判断SQL错误代码,如果是没有这个数据库文件,则根据所提供滴模式创建
conn = dbMgr.createDatabase( parms );
System.out.println("已经根据所提供的UltraLite模式创建数据库");
}else{
econn.printStackTrace();
}
}
}
private void insert() throws SQLException{
Table t = conn.getTable( "customer" );
t.open();
short id = t.schema.getColumnID( "id" );
short fname = t.schema.getColumnID( "fnamee" );
short lname = t.schema.getColumnID( "lnamee" );
if( t.getRowCount() == 0 ) {
//判断数据库里面是否有数据,有则不再添加,没有就添加。。。
// 你不要告诉我你这样还不知道怎么去改这个地方
t.insertBegin();
t.setString( fname, "li" );
t.setString( lname, "you" );
t.insert();
conn.commit();
System.out.println( "向数据库添加数据!" );
}else{
System.out.println( "数据库里面已经有了数据!" );
}
t.close();
}
private void select() throws SQLException{
Table t = conn.getTable("customer");
t.open();
short id = t.schema.getColumnID( "id" );
short fname = t.schema.getColumnID( "fnamee" );
short lname = t.schema.getColumnID( "lnamee" );
t.moveBeforeFirst();
while( t.moveNext() ) {
System.out.println(
"id= " + t.getInt( id )
+ ", 姓名= " + t.getString( fname )
+ " " + t.getString( lname )
+"\n哈哈哈,成功了吧!你小子回来请我吃饭!帮你做了好多这种事情了!");
}
t.close();
}
}

原文转自:http://www.ltesting.net