新网创想网站建设,新征程启航
为企业提供网站建设、域名注册、服务器等服务
//定义驱动名
成都创新互联主营江城网站建设的网络公司,主营网站建设方案,重庆App定制开发,江城h5重庆小程序开发搭建,江城网站营销推广欢迎江城等地区企业咨询
String url =
"jdbc:oracle:thin:@**.**.**.**:1521:";//定义数据库的链接语句,**表示你要链接的数据库的ip地址。当然如果你的本机上有oracle也可以写成127.0.0.1或者localhost,""表示你的数据库名称。Stringusername ="scott";
//你登陆数据库的用户名
String password ="*******";
//你登陆数据库的密码Stringsql= "insert into users(username,password)
values(?,?)";
//插入数据的命令语句try{
Class.forName(driver);Connectionconn = DriverManager. getConnection_r(url,
username,password);
PreparedStatement
pstmt = conn.prepareStatement(sql);
pstmt.setString(1,
"god");
//当然为了方便我这是随便插入的数据
pstmt.setString(2,
"god");//同上
pstmt.executeUpdate();
pstmt.close();
conn.close();
//完成后关闭链接
} catch (ClassNotFoundException e) {
e.printStackTrace();
} catch (SQLExceptione) {
e.printStackTrace();}}}程序运行完成后你就会在你的数据库里看到多了一条记录username:god
password:god,另外我们觉得这篇博文的读者应该是那些对oracle数据库有一定的了解的程序开发爱好者源码天空
,如果你还不了解oracle,那你就需要对数据库有一定的了解这后再来看这篇博文。
对于一个热衷于程序设计的人来说,我们认为最主要的是你的程序一定要有一定的标准,我们认为这个例子是链接数据库最标准的方法。当然仁者见仁嘛
1. 获得远程数据库的tns信息和要访问的对象的拥有者及其密码
2.创建dblink
create database link "DBLINK_NAME" connect to "USER_NAME" identified by "PASSWD" using ' (DESCRIPTION =
(ADDRESS = (PROTOCOL = TCP)(HOST = lnwxzyp)(PORT = 1521))
(CONNECT_DATA =
(SERVER = DEDICATED)
(SERVICE_NAME = demo)
)
)
';
3.查看
select * from view_name@dblink_name;
也可以建成同义词
create synonym OBJ_NAME for view_name@dblink_name;
建成视图
create view VIEW_NAME as select * from view_name@dblink_name;
这样读取:declare /*声明PL/SQL中程序块中的变量info_var,用户存放查询到的info列的数据,其类型必须和表中的字段类型一致*/ info_var clob; --查询数据长度 amount integer; --偏移量,查询起始位置 offset integer; --需要打印的字节,存储变量 info_output varchar2(1000); begin --查询要打印的字段信息并赋值给info_var select info into info_var from t_clob where id = 1; --查询100长度 amount :=100; --从第一个开始 offset :=1; --用dbms_lob程序包读取数据 dbms_lob.read(info_var,amount,offset,info_var); --用dbms_lob程序包打印读取得数据info_var dbms_output.put_line(info_var); end; /
这个其实最好是做stream,这样可以保证同步更新。但是如果为了一张表做stream看起来又有些不那么值当。
dblink无法远程提交,我只能勉强提出一个方案供参考。
首先数据库AB间互相建立dblink;也就是两个dblink(A到B,B到A)
另外A数据库连接B数据库,所用的B数据库的用户是一个特殊的用户,除了这个dblink以外,其他的地方根本用不到的。
B到A的触发器则只需要读取权限就可以了。
在数据库A上建立触发器,after insert后触发,触发的内容是利用dblink登陆B数据库,登陆后随便查询个什么,都可以然后退出登陆。(直接退出也可以,主要是怕数据库记录不到登陆,登陆触发器有时似乎不那么好用,如果实在不好用可以在这个特殊用户 建立一张表,然后每次登陆都drop这张表,用drop触发器,这个没问题)
B数据库建立一个登陆触发器(或drop触发器),只要那个特殊用户登陆,那么就启动,就是查询A数据库的表a,然后更新表b,然后提交。如果是drop或create触发器,别忘了再重新create和drop,不然表会越来越多或者无表drop。
1、首先在计算机中,打开Oracle的连接程序,查看表中重复的数据。
2、然后使用distinct,去除函数查询出去掉重复后的数据。
3、接着创建新表,把去掉重复的数据插入到新表中。
4、然后使用truncate,清空原表中的数据。
5、最后再向原表中插入新表中重复的数据,即可达到去重复数据的效果。
错误没贴出来。 我只能猜测:
string sql = "select * from t_users where USER=@USER and PASS=@PASS";
string[,] UserInfo = { { "@Uname", loginInfo.UName }, { "@UID", loginInfo.UPassword } };
改成
string sql = "select * from t_users where USER=:USER and PASS=:PASS";
string[,] UserInfo = { { "Uname", loginInfo.UName }, { "UID", loginInfo.UPassword } };
试试