Oracle数据库同一个实例下不同用户表名重复的问题

     首先我们要明确:表名和用户没有关系,关键的一个实例下,不能有相同的表名存在。也就是说Oracle数据库系统中,可以有多个数据库,每一个数据库可以有多个数据表。同一个数据库中不能有相同名称的数据表,但在不同的数据库中可以有相同的数据表名。
    通常情况我们都是在一个数据库实例下创建多个用户,因此就会出现不同用户下表名重复时,hibernate映射表映射不出来的问题,解决办法就是在访问数据库表时采用“用户名.表名”的方式。具体的实现方法有两种:
1:在hiberante.properties文件里,设置hibernate.default_schema="用户名",注:用户名要大写。2 :如果使用SH框架,在jdbc文件中配置一个用户名(username),在sessionFactory的配置文件中,加上<prop key="hibernate.default_schema">${jdbc.username}</prop>来读取这个用户名,当然也可以直接把用户名写死,但一般为了灵活,不建议写死。加上这个配置项也就表示在每次访问表时在前加上用户名。

 

                
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值