有关jndi和DataSource菜鸟问题

zydgyy 2005-11-01 07:29:03
import com.microsoft.jdbcx.sqlserver.SQLServerDataSource;
import javax.sql.*;
import java.sql.*;
import javax.naming.*;
import java.util.Hashtable;

public class Test {

public static void main(String[] args) {

try {

Test t = new Test();
t.bindDataSource ();
Connection con = t.getConnection ();
}
catch(NamingException e) {
System.out.println("namingException:"+e.getMessage ());

}
catch(SQLException e) {
System.out.println ("sqlException:"+e.getMessage ());
}

}

public Connection getConnection() throws NamingException,SQLException{

Hashtable<String,String> env = new Hashtable<String,String>();
env.put (Context.INITIAL_CONTEXT_FACTORY,"com.sun.jndi.ldap.LdapCtxFactory");
env.put (Context.PROVIDER_URL,"ldap://zhouyu:389");
Context ctx = new InitialContext(env);
DataSource dataSource = (DataSource)ctx.lookup ("jdbc/TestDB");

return dataSource.getConnection ("zydgyy","19831009");
}

public void bindDataSource() throws NamingException,SQLException{

SQLServerDataSource dataSource = new SQLServerDataSource();
dataSource.setServerName ("ZHOUYU");
dataSource.setDatabaseName("jiAnMobile");
dataSource.setPortNumber(1433);
//dataSource.setUser("zydgyy");
//dataSource.setPassword("19831009");
Hashtable<String,String> env = new Hashtable<String,String>();
env.put (Context.INITIAL_CONTEXT_FACTORY,"com.sun.jndi.ldap.LdapCtxFactory");
env.put (Context.PROVIDER_URL,"ldap://zhouyu:389");
Context ctx = new InitialContext(env);

ctx.bind ("jdbc/TestDB",dataSource);
}
}
...全文
197 3 打赏 收藏 转发到动态 举报
写回复
用AI写文章
3 条回复
切换为时间正序
请发表友善的回复…
发表回复
zydgyy 2005-11-10
  • 打赏
  • 举报
回复
那位大虾写一个完整的利用数据源连接数据库的例子,包过怎样配置.最好是mssql的.
zydgyy 2005-11-03
  • 打赏
  • 举报
回复
没有那位大虾帮我解决一下吗?
小弟在线等...
zydgyy 2005-11-01
  • 打赏
  • 举报
回复
这个程序运行得到了ldap://zhouyu:389 socket closed异常

62,614

社区成员

发帖
与我相关
我的任务
社区描述
Java 2 Standard Edition
社区管理员
  • Java SE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧