首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

PreparedStatement保留JNDI中的会话设置

PreparedStatement是Java中的一个接口,用于执行预编译的SQL语句。它可以在执行相同SQL语句多次时提供更好的性能和安全性。

JNDI(Java Naming and Directory Interface)是Java中的一个API,用于访问命名和目录服务。它提供了一种统一的方式来访问各种命名和目录服务,如LDAP(轻量级目录访问协议)和DNS(域名系统)。

当使用PreparedStatement时,可以通过JNDI来保留会话设置。具体来说,可以将数据库连接信息配置在JNDI中,然后在代码中通过JNDI来获取数据库连接。这样做的好处是可以将数据库连接的配置信息与代码分离,方便管理和维护。

使用JNDI保留会话设置的步骤如下:

  1. 在应用程序的配置文件中配置JNDI数据源,包括数据库连接信息和其他相关配置。
  2. 在代码中通过JNDI API来获取数据库连接,可以使用javax.naming.InitialContext类的lookup方法。
  3. 使用获取到的数据库连接创建PreparedStatement对象,并执行相应的SQL语句。

使用JNDI保留会话设置的优势包括:

  1. 配置分离:将数据库连接信息配置在JNDI中,可以将其与代码分离,方便管理和维护。
  2. 灵活性:可以在不修改代码的情况下更改数据库连接信息,如数据库地址、用户名、密码等。
  3. 安全性:敏感的数据库连接信息可以被保护起来,只有授权的人员才能访问。

适用场景:

  1. 多环境部署:当应用程序需要在不同的环境中部署(如开发、测试、生产环境),可以使用JNDI来配置不同的数据库连接信息。
  2. 数据库连接池:当应用程序需要使用数据库连接池管理数据库连接时,可以将连接池配置在JNDI中,通过JNDI获取连接。

腾讯云相关产品推荐: 腾讯云提供了多个与云计算相关的产品,以下是其中几个与数据库连接相关的产品:

  1. 云数据库 TencentDB:腾讯云的云数据库服务,提供了多种数据库引擎的支持,包括MySQL、SQL Server、MongoDB等。可以通过腾讯云控制台或API来管理和配置数据库实例。
  2. 云数据库Redis:腾讯云的云数据库Redis服务,提供了高性能的内存数据库服务。可以通过腾讯云控制台或API来管理和配置Redis实例。
  3. 云数据库CynosDB:腾讯云的云数据库CynosDB服务,提供了高可用的分布式数据库服务。支持MySQL和PostgreSQL引擎,可以通过腾讯云控制台或API来管理和配置CynosDB实例。

以上是腾讯云提供的几个与数据库连接相关的产品,更多产品信息可以参考腾讯云官方网站:https://cloud.tencent.com/product

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

EJB学习心得

一:当EJB发布到JBOSS时,如果我们没有为它指定全局JNDI名称或修改其默认的EJB名称, JBOSS就会按照默认的命名规则为EJB生成全局JNDI名称。默认的命名规则如下: 如果把EJB作为模块打包进后缀*.ear的JAVA EE企业应用文件,默认的全局JNDI名称是 本地接口:EAR-FILE-BASE-NAME/EJB-CLASS-NAME/local 远程接口:EAR-FILE-BASE-NAME/EJB-CLASS-NAME/remote 如果把EJB应用打包成后缀为*.jar的模块文件,默认的全局JNDI名称是 本地接口:EJB-CLASS-NAME/local 远程接口:EJB-CLASS-NAME/remote 二:通过远程接口调用EJB的过程 首先客户端需要和EJB服务器建立Socket通信,在通信管道上他们需要来回发送IIOP协议消息。 因为数据要在网络进行传输,存放数据的JAVA对象必须要序列化。 三:通过本地接口调用EJB的过程 通过本地接口调用EJB,直接在内存中进行交互,这样可以避免网络开销、协议解析的开销和对象序列化的开销。 但是大家必须要注意,只有客户端与EJB应用在同一个JVM内运行的时候,我们才能调用本地接口 。 四:如何通过使用注解方式注入并使用其他的EJB和服务 注入和使用其他EJB的方式如下: @EJB EJB的接口 EJB的变量 通过注解”@EJB”可以注入并使用其他的EJB,如果有多个EJB的类实现了同一个接口,那么在使用”@EJB”的时候 需要明确指定是注入和使用哪一个EJB的Bean。指定方式如下: @EJB(beanName=”EJB类的名称”) EJB的接口 EJB的变量 注入和使用其他服务的方式如下: @Resource 服务名称 服务变量 注意在指定数据源的使用需要配置mappedName的属性值,例如: @Resource(mappedName=”数据库的JNDI名称”) DataSource dataSource 五:JMS中的消息 消息传递系统的中心是消息,一条消息有三部分组成 头(Header),属性(property),主体(body) 消息有以下几种类型,他们都是派生自Message接口 StreamMessage:一种主体中包含JAVA基原值流的消息,如填充和读取均按顺序进行。 MapMessage:一种主体中包含一组名-值对的消息,没有定义条目顺序 TextMessage:一种主体中包含JAVA字符串的消息(例如:XML消息) ObjectMessage:一种主体中包含序列化的JAVA对象的消息 BytesMessage:一种主体中包含连续字节流的消息 消息的传递模型为以下两种: 点对点(point-to-point:PTP):该消息传递模型规定,一条消息只能传递给一个接收方,可以接受过时的消息。采用javax.jms.Queue表示。 发布/订阅(publish/subscribe):该消息传递模型规定,一条消息可以传递给多个接收方,只能接受实时的消息。采用javax.jms.Topic表示。 六:如何发送消息(以Queue为例,如果是Topic则应把所有的Queue改为Topic) 1.得到一个JNDI的初始化上下文(Context) InitialContext ctx = new InitialContext(); 2.根据上下文查找一个连接工厂QueueConnectionFactory。该连接工厂是用JMS提供的,不需要我们自己创建, 每个工厂都绑定一个全局的JNDI,我们通过全局的JNDI来获取它 QueueConnectionFactory factory = (QueueConnectionFactory)ctx.lookup(“QueueConnectionFactory”); 3.通过连接工厂得到一个连接QueueConnection QueueConnection conn = factory.createQueueConnection(); 4.通过连接来建立一个会话(Session) QueueSession session = conn.createQueueSession(false,QueueSession.AUTO_ACKNOWLEDGE); 建立一个不需要事物的并且能启动确认消息已接受的会话 5.查找目标地址 Destination destination = (Destination)ctx.lookup(配置文件的JNDI名称); 6.根据会话和目标地址来建立消息生产者MessageProducer MessageProducer producer = session.crea

01

Mybatis 详解

每个基于 MyBatis 的应用都是以一个 SqlSessionFactory 的实例为核心的。SqlSessionFactory 的实例可以通过 SqlSessionFactoryBuilder 获得。而 SqlSessionFactoryBuilder 则可以从 XML 配置文件或一个预先定制的 Configuration 的实例构建出 SqlSessionFactory 的实例。   从 XML 文件中构建 SqlSessionFactory 的实例非常简单,建议使用类路径下的资源文件进行配置。 但是也可以使用任意的输入流(InputStream)实例,包括字符串形式的文件路径或者 file:// 的 URL 形式的文件路径来配置。MyBatis 包含一个名叫 Resources 的工具类,它包含一些实用方法,可使从 classpath 或其他位置加载资源文件更加容易。   XML 配置文件中包含了对 MyBatis 系统的核心设置,包含获取数据库连接实例的数据源(DataSource)和决定事务作用域和控制方式的事务管理器(TransactionManager)。要注意 XML 头部的声明,它用来验证 XML 文档正确性。environment 元素体中包含了事务管理和连接池的配置。mappers 元素则是包含一组映射器(mapper),这些映射器的 XML 映射文件包含了 SQL 代码和映射定义信息。   配置文件中标签要按照顺序书写 properties ☞ settings ☞ typeAliases ☞ typeHandlers ☞ objectFactory ☞ objectWrapperFactory ☞ reflectorFactory ☞ plugins ☞ environments ☞ databaseIdProvider mappers

02

java学习与应用(5.1)--Mybatis

mybatis框架,java持久层框架,ORM(Object Relational Mapping对象关系映射)思想实现结果集封装。 三层架构(表现层展示数据,业务层实现业务需求,持久层和数据库交互[JDBC技术规范、Spring的Template和Apache的DBUtils工具类,都不属于框架]) maven的pom.xml下的packaging为打包方式,其他依赖代码可以通过官网复制。 创建实体类和dao接口,在resources包下的SqlMapConfig.xml中进行mybatis的主配置文件,配置环境,事务类型,配置映射文件类型等。然后建立,IUserDao.xml(IUserMapper)中写入映射配置文件,定义结果值封装类型,语句等,建立的路径和main.java.xxx.xxx.IUserDao.java对应。 映射配置文件的mapper标签namespace属性的取值必须是dao接口的全限定类名,映射配置文件的操作配置(select) ,id属性的取值必须是dao接口的方法名。接口dao的实现类使用mybatis。 流程为:读取配置文件Resources.getResourceAsStream,创建SqlSessionFactory工厂,使用工厂生产SqlSession对象,使用SqlSession创建Dao的代理对象,使用代理对象执行方法,最后释放资源。见图 使用注解代替xml映射配置文件,在接口方法上使用@Select("sql语句")。

01
领券