C#使用ip连接数据库出错,sql server2008
怎么使用ip地址连接局域网内电脑的数据库。我这样写的错了。ip地址写的是本机的局域网ip地址...
怎么使用ip地址连接局域网内电脑的数据库。 我这样写的错了。 ip地址写的是本机的局域网ip地址
展开
展开全部
"server=192.168.1.7;database=database;uid=sa;pwd=123456"
我的字符串就是这样的.
不过我看你的也差不多哈,
你试试在MSSQL的管理器里面,用这个地址和用户名密码看能不能接入.
using System;
using System.Collections.Generic;
using System.Text;
using System.Configuration;
using System.Data;
using System.Data.SqlClient;
public static class DBHelper
{
private static SqlConnection connection;
public static SqlConnection Connection
{
get
{
try
{
string connectionString = ConfigurationManager.ConnectionStrings["sysConn"].ToString();
if (connection == null)
{
connection = new SqlConnection(connectionString);
connection.Open();
}
else if (connection.State == System.Data.ConnectionState.Closed)
{
connection.Open();
}
else if (connection.State == System.Data.ConnectionState.Broken)
{
connection.Close();
connection.Open();
}
}
catch (Exception ex) { throw ex; }
return connection;
}
}
public static int ExecuteCommand(string safeSql)
{
SqlCommand cmd = new SqlCommand(safeSql, Connection);
int result = cmd.ExecuteNonQuery();
return result;
}
public static void ExecuteCommand(string sql, CommandType type, SqlParameter[] para)
{
SqlCommand cmd = new SqlCommand();
cmd.Connection = Connection;
cmd.CommandText = sql;
cmd.CommandType = type;
cmd.Parameters.AddRange(para);
cmd.ExecuteNonQuery();
}
public static int ExecuteCommand(string sql, params SqlParameter[] values)
{
SqlCommand cmd = new SqlCommand(sql, Connection);
cmd.Parameters.AddRange(values);
return cmd.ExecuteNonQuery();
}
public static int GetScalar(string safeSql)
{
SqlCommand cmd = new SqlCommand(safeSql, Connection);
int result = Convert.ToInt32(cmd.ExecuteScalar());
return result;
}
public static int GetScalar(string sql, params SqlParameter[] values)
{
SqlCommand cmd = new SqlCommand(sql, Connection);
cmd.Parameters.AddRange(values);
int result = Convert.ToInt32(cmd.ExecuteScalar());
return result;
}
public static SqlDataReader GetReader(string safeSql)
{
SqlCommand cmd = new SqlCommand(safeSql, Connection);
SqlDataReader reader = cmd.ExecuteReader();
return reader;
}
public static SqlDataReader GetReader(string sql, params SqlParameter[] values)
{
SqlCommand cmd = new SqlCommand(sql, Connection);
cmd.Parameters.AddRange(values);
SqlDataReader reader = cmd.ExecuteReader();
return reader;
}
public static DataTable GetDataSet(string safeSql)
{
DataSet ds = null;
SqlCommand cmd = null;
SqlDataAdapter da = null;
try
{
ds = new DataSet();
cmd = new SqlCommand(safeSql, Connection);
da = new SqlDataAdapter(cmd);
da.Fill(ds);
}
catch (SqlException se) { throw se; }
catch (Exception ex) { throw ex; }
finally { da.Dispose(); cmd.Dispose(); ds.Dispose(); }
return ds.Tables[0];
}
public static DataTable GetDataSet(string sql, params SqlParameter[] values)
{
DataSet ds = new DataSet();
SqlCommand cmd = new SqlCommand(sql, Connection);
cmd.Parameters.AddRange(values);
SqlDataAdapter da = new SqlDataAdapter(cmd);
da.Fill(ds);
return ds.Tables[0];
}
}
下面是在webconfig里面设定的东西
<connectionStrings>
<add name="sysConn" connectionString="Data Source=192.168.1.9;Initial Catalog=DATAname;User ID=sa;Password=123456"
providerName="System.Data.SqlClient" />
</connectionStrings>
这里就是调用的方法:
string strSql = @"SELECT getdate()";
public DataTable SateViewTB;
SateViewTB = DBHelper.GetDataSet(strSql);
这里是一个C#连接数据库的类
追问
DBHelper,I know! 管理器在哪
追答
你的安装SQL就会有企业管理器啊
就是 SQL Server Management Studio
展开全部
如果是本机的数据库,可以试着使用这样的链接字符串
Data Source=.;Initial Catalog=DataBaseName;Integrated Security=True
//DataBaseName是你的数据库名
Data Source=.;Initial Catalog=DataBaseName;Integrated Security=True
//DataBaseName是你的数据库名
追问
我的目的是要连接其他机器的数据库。问题是,我用ip地址连自己的数据库都连不上,怎么去连接其他机器上的数据库。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
你在电脑---开始---运行 输入 \\192.168.1.107 看看访问是否正常。
追问
这是本机的地址, 可以ping通的, 我试了下你这个,报错,文件名、目录名或语法不正确
追答
可以ping通不代表你可以访问这部电脑的,你没有访问权限的话是用不了的,你找你们的网络管理员看看吧,在电脑开始运行这个不会报错的 \\192.168.1.107
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
你试试localhost可以不
追问
可以,localhost可以远程连接么? 我如果要连接本机我直接用.了
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询