SQL Server数据库远程操作

SQL Server数据库远程操作中,在使用openrowset/opendatasource前首先要启用Ad Hoc Distributed Queries服务,因为这个服务不安全所以SqlServer默认是关闭的。

1、启用Ad Hoc Distributed Queries的方法

SQL Server 阻止了对组件‘Ad Hoc Distributed Queries‘ 的STATEMENT‘OpenRowset/OpenDatasource‘的访问,因为此组件已作为此服务器安全配置的一部分而被关闭。系统管理员可以通过使用。sp_configure 启用 ‘Ad Hoc Distributed Queries‘。

启用Ad Hoc Distributed Queries的方法,执行下面的查询语句就可以了:

  1. exec sp_configure ‘show advanced options‘,1
  2. reconfigure
  3. exec sp_configure ‘Ad Hoc Distributed Queries‘,1
  4. reconfigure

使用完毕后,记得一定要关闭它,因为这是一个安全隐患,切记执行下面的SQL语句:

  1. exec sp_configure ‘Ad Hoc Distributed Queries‘,0
  2. reconfigure
  3. exec sp_configure ‘show advanced options‘,0
  4. reconfigure

2、使用示例

创建链接服务器

  1. exec sp_addlinkedserver   ‘ITSV ‘, ‘ ‘, ‘SQLOLEDB ‘, ‘远程服务器名或ip地址 ‘
  2. exec sp_addlinkedsrvlogin ‘ITSV ‘, ‘false ‘,null, ‘用户名 ‘, ‘密码 ‘

查询示例

  1. select * from ITSV.数据库名.dbo.表名

导入示例

  1. select * into 表 from ITSV.数据库名.dbo.表名

以后不再使用时删除链接服务器

  1. exec sp_dropserver  ‘ITSV ‘, ‘droplogins ‘

3、连接远程/局域网数据(openrowset/openquery/opendatasource) 

1、openrowset 

查询示例

  1. select * from openrowset( ‘SQLOLEDB ‘, ‘sql服务器名 ‘; ‘用户名 ‘; ‘密码 ‘,数据库名.dbo.表名)

生成本地表

  1. select * into 表 from openrowset( ‘SQLOLEDB ‘, ‘sql服务器名 ‘; ‘用户名 ‘; ‘密码 ‘,数据库名.dbo.表名)

把本地表导入远程表

  1. insert openrowset( ‘SQLOLEDB ‘, ‘sql服务器名 ‘; ‘用户名 ‘; ‘密码 ‘,数据库名.dbo.表名)
  2. select *from 本地表

更新本地表

  1. update b
  2. set b.列A=a.列A
  3. from openrowset( ‘SQLOLEDB ‘, ‘sql服务器名 ‘; ‘用户名 ‘; ‘密码 ‘,数据库名.dbo.表名)as a inner join 本地表 b
  4. on a.column1=b.column1

openquery用法需要创建一个连接。

首先创建一个连接创建链接服务器

  1. exec sp_addlinkedserver   ‘ITSV ‘, ‘ ‘, ‘SQLOLEDB ‘, ‘远程服务器名或ip地址 ‘

查询

  1. select * FROM openquery(ITSV,  ‘SELECT *  FROM 数据库.dbo.表名 ‘)

把本地表导入远程表

  1. insert openquery(ITSV,  ‘SELECT *  FROM 数据库.dbo.表名 ‘)
  2. select * from 本地表

更新本地表

  1. update b
  2. set b.列B=a.列B
  3. FROM openquery(ITSV,  ‘SELECT * FROM 数据库.dbo.表名 ‘) as a
  4. inner join 本地表 b on a.列A=b.列A

2、opendatasource/openrowset 

  1. SELECT   * FROM   opendatasource( ‘SQLOLEDB ‘,  ‘Data Source=ip/ServerName;User ID=登陆名;Password=密码 ‘ ).test.dbo.roy_ta

把本地表导入远程表:

  1. insert opendatasource( ‘SQLOLEDB ‘,  ‘Data Source=ip/ServerName;User ID=登陆名;Password=密码 ‘).数据库.dbo.表名
  2. select * from 本地表

关于SQL Server数据库中使用T-SQL语句访问远程数据库的操作就介绍到这里了,希望本次的介绍能够对您有所收获!

时间: 2024-10-08 22:26:35

SQL Server数据库远程操作的相关文章

sql server 数据库的操作

Technorati 标记: sql截取,sql修改 把一个字段的部分取出来,插入到新字段 1 update tablename set b = left(a,8) //方法一2 update tablename set b = substring(a,1,8)  //方法二 sql server修改一个字段中的部分数据  update tablename set 字段=replace(字段,'初始内容','替换内容')

SQL Server数据库DML操作

补充: 1.删除数据库: 例子:drop database 学生数据库 2.删除表 例子:drop table 学生表 1.在表中增加数据 例子: insert into学生表(学号,姓名,性别,出生日期,政治面貌) values(43,'yyw','男','2000-7-5,'党员''); 2.在表中更改数据 例子 update 学生表 set 姓名='yyh' where 学号=43; 3.在表中删除数据 例子 delete from 学生表 where 学号=43: delete from

C#操作access和SQL server数据库代码实例

在C#的学习中,操作数据库是比较常用的技术,而access和sql server 数据库的操作却有着不同.那么,有哪些不同呢? 首先,需要引用不同的类.因为有着不同的数据引擎. access:using System.Data.OleDb; sql server:using System.Data.SqlClient; 下面是我写的access和sql 数据库操作的两个类: 1 //1.操作sql数据库的类 2 public class DBOperSQL1 3 { 4 public stati

中琅领跑标签条码打印软件如何连接sql server数据库

使用中琅领跑标签条码打印软件制作商品条码过程中,如果数据储存在excel表或文本文档中时,根据之前教程,我们可以轻松连接使用其中的数据.但如果数据是存储在远方主机或数据库中,我们如何获取使用呢?这里小编就简单介绍下中琅领跑标签条码打印软件数据库连接的基本操作步骤,以sql server 2000为例,其他数据库如mysql,oracle等连接步骤大致相同.首先,无论是您的数据库是安装在本机还是远方服务器上,请确保sql server是可以连接的.需要注意的是,针对sql server 2000的

[转]C#操作SQL Server数据库

转自:C#操作SQL Server数据库 1.概述 ado.net提供了丰富的数据库操作,这些操作可以分为三个步骤: 第一,使用SqlConnection对象连接数据库: 第二,建立SqlCommand对象,负责SQL语句的执行和存储过程的调用: 第三,对SQL或存储过程执行后返回的“结果”进行操作. 对返回“结果”的操作可以分为两类: 一是用SqlDataReader直接一行一行的读取数据集: 二是DataSet联合SqlDataAdapter来操作数据库. 两者比较: SqlDataRead

C#操作SQL Server数据库

C#操作SQL Server数据库 1.概述 2.连接字符串的写法 3.SqlConnection对象 4.SqlCommand对象 5.SqlDataReader对象 6.DataSet对象 7.释放资源 1.概述 ado.net提供了丰富的数据库操作,这些操作可以分为三个步骤: 第一,使用SqlConnection对象连接数据库: 第二,建立SqlCommand对象,负责SQL语句的执行和存储过程的调用: 第三,对SQL或存储过程执行后返回的"结果"进行操作. 对返回"结

使用SQL Server 2008远程链接时SQL数据库不成功的解决方法

远程连接SQL Server 2008,服务器端和客户端配置 关键设置: 第一步(SQL2005.SQL2008): 开始-->程序-->Microsoft SQL Server 2008(或2005)-->配置工具-->SQL Server 配置管理器-->SQL Server网络配置-->MSSQLSERVER(这个名称以具体实例名为准) 的协议-->TCP/IP-->右键-->启用 第二步: SQL2005: 开始-->程序-->Mi

详解连接SQL Server数据库的方法,并使用Statement接口实现对数据库的增删改操作

总结一下,连接SQL Server数据库需要以下几个步骤: 1. 导入驱动Jar包:sqljdbc.jar 2. 加载并注册驱动程序 3. 设置连接路径 4. 加载并注册驱动 5. 连接数据库 6. 操作数据库 7. 关闭连接 代码如下: ******************连接数据库******************* 1 package zj6_Test; 2 import java.sql.*; 3 public class Zj6_3 { 4 /** 5 * 使用Statement接口

基于Spring Boot,使用JPA操作Sql Server数据库完成CRUD

完成一个RESTful服务,提供几个访问接口,用来操作较简单的联系人信息,数据保存在Sql Server数据库中. 1.使用STS创建工程. 使用STS创建RESTful工程,可以参考: <用Spring Tools Suite(STS)开始一个RESTful Web Service><SpringBoot构建RESTful service完成Get和Post> 新建项目时的Project Name,Group,Atifact,Package这些参数按照实际要求填. 项目引入依赖w