IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> DataSource接口和一些扩展 -> 正文阅读

[大数据]DataSource接口和一些扩展

序言

上次说到了Manager,这次来说一下获得链接的第二种方式。javax.sql.DaraSource以及JNDI API和连接的关闭。

javax.sql.DaraSource

javax.sql.DaraSource接口最早是由JDBC2.0版本扩展包提供的,它是比较推荐的获得数据源连接的一种方式,JDBC驱动程序都会实现DataSource接口,通过DataSource实现类的实例,返回一个Connection接口的实现类的实例。

使用DataSource对象可以提高应用程序的可移植性。在应用程序中,可以通过逻辑名称来获取DataSource对象。DataSource对象用于表示能够提高数据库连接的数据源对象。如果数据库相关的关系发生了改变,则可以简单的修改DataSource对象的属性来反应这种变化,而不用修改应用程序的任何代码。

DataSource接口可以被实现,提高如下两种功能:
通过连接池提高系统性能和伸缩性。
通过XADataSource接口支持分布式事务

注意:DataSource实现类必须包含一个无参构造方法

其属性有:
databaseName:数据库名称
dataSourceName:数据源名称
description:数据源描述信息
networkProtocol:与数据库服务器交互的网络协议
password:数据库密码
portNumber:数据库监听端口
roleName:角色名称
serverName:数据库服务器名称
user:用户名

DataSource对象不建议被JDBC客户端直接访问。

使用JNDI API增强应用的可移植性

what?

JNDI是Java命名和目录接口,它为应用程序提供了一种通过网络访问远程服务的方式。

why?

通过jndi访问抽象的资源。这样程序不至于与访问的资源耦合。比如用jndi数据库密码变了与程序无关。不需要改代码。JNDI API的命令服务把一个逻辑名称和一个具体的对象绑定,使用它,可以通过和DataSource绑定的逻辑名称直接获得DataSource对象。当DataSource的属性发生改变时,不需要需要代码。无感知的修改。

how?

直接上代码

    <dependency>
            <groupId>tomcat</groupId>
            <artifactId>naming-java</artifactId>
            <version>5.0.28</version>
        </dependency>
        <dependency>
            <groupId>tomcat</groupId>
            <artifactId>naming-common</artifactId>
            <version>5.0.28</version>
        </dependency>

        <dependency>
            <groupId>commons-logging</groupId>
            <artifactId>commons-logging</artifactId>
            <version>1.2</version>
        </dependency>
public class Test1 {
	Properties jdniProp = null;
	Context ctx = null;
	@Before
	public void before() throws Exception{
		// 创建数据源工厂
		DataSourceFactory dataSourceFactory = new UnpooledDataSourceFactory();
		Properties properties = new Properties();
		InputStream stream = Thread.currentThread().getContextClassLoader().getResourceAsStream("db1.properties");
		properties.load(stream);
		dataSourceFactory.setProperties(properties);
		DataSource dataSource = dataSourceFactory.getDataSource();
		try {
			jdniProp = new Properties();
//			指定到目录服务的连接工厂
			jdniProp.put(Context.INITIAL_CONTEXT_FACTORY,"org.apache.naming.java.javaURLContextFactory");
			jdniProp.putIfAbsent(Context.URL_PKG_PREFIXES,"org.apache.naming");
			ctx = new InitialContext(jdniProp);
			// 绑定
			ctx.bind("java:TestCB",dataSource);
		}catch (Exception e){
			System.err.println(e.getMessage());
		}
	}
	
	@Test
	public void test(){
		try {
			DataSource dataSource = (DataSource) ctx.lookup("java:TestCB");
			Connection connection = dataSource.getConnection();
			Statement statement = connection.createStatement();
			ResultSet resultSet = statement.executeQuery("select * from blog");
			while (resultSet.next()){
				String bid = resultSet.getString("bid");
				System.out.println(bid);
			}
		}catch (Exception e){
		
		}
	}
	
}

UnpooledDataSourceFactory是指没有实现连接池。
创建了一个 java.naming.InitalContext实例,调用该实例的bind创建命令服务,可以通过lookup()查找服务,它是一个上下文对象。我们也可以用Tomcat来配置JNDI数据源。

关闭连接

用完Connection之后,需要显示的对其关闭,除了close以外,还提供了一个isClose方法,判断连接是否关闭,isValid方法判断连接是否有效。

结束语

码字不易,请给个赞把,谢谢!
下一章 讲一个Statement.

  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2022-09-13 11:22:42  更:2022-09-13 11:24:00 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/23 11:10:06-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码