2 qq724432055 qq724432055 于 2015.06.16 22:53 提问

如何在c#窗口应用程序中打开一个数据库

在下新手,在数据库编程时做书上的例子,通过c#程序登录界面,登录到一个数据库,我使用了本地服务器。在SQL server management studio中,使用账号sa以sqlserver身份验证方式可以登录服务器名为HY-20141014UKZE\SQLEXPRESS的数据库引擎,并且创建了一个名为Fiancing的数据库, 参考书上的例子如下,怎么样可以在这个c#程序中登录Fiancing数据库?
private void btnLogin_Click(object sender, EventArgs e)
{
string userName = txtName.Text.Trim();//Trim()用于去除文本框中的前后空格
string password = txtPwd.Text.Trim();
string connString = "Data Source=.;Initial Catalog=Financing;User ID=sa;Pwd=123456";
SqlConnection conn = new SqlConnection(connString);//创建Connection对象
//获取用户名和密码匹配的行的数量的SQL语句
string sql = String.Format("select count(*)from User where UserName='{0}'and Password='{1}'",userName,password);
try
{
conn.Open();//打开数据库连接
SqlCommand comm = new SqlCommand(sql, conn);//封装sql命令
int num = (int)comm.ExecuteScalar();//执行sql命令
if (num ==1)
{
//如果有匹配的行,则表明用户名和密码正确
MessageBox.Show("欢迎进入个人理财系统!", "登陆成功", MessageBoxButtons.OK, MessageBoxIcon.Information);
MainFrm mainForm=new MainFrm();
mainForm.Show();
this.Visible=false;
}
else
{
txtPwd.Text="";//清除文本框中的内容
MessageBox.Show("您输入的用户名或密码有误!", "登录失败", MessageBoxButtons.OK, MessageBoxIcon.Exclamation);
}
}
catch (System.Exception ex)
{
MessageBox.Show(ex.Message, "操作数据库出错!", MessageBoxButtons.OK, MessageBoxIcon.Exclamation);
}
finally
{
conn.Close();
}

    }

3个回答

devmiao
devmiao   Ds   Rxr 2015.06.16 22:57

关键是一个你数据库建表是不是和书上程序一样
一个是连接字符串string connString = "Data Source=.;Initial Catalog=Financing;User ID=sa;Pwd=123456";,代表了sql server是本机默认实例,初始数据库Financing,使用混合验证,用户名sa密码123456,这些和你的设置一样么?

gamefinity
gamefinity   Rxr 2015.06.17 06:14
 string connString = "Data Source=.;Initial Catalog=Financing;User ID=sa;Pwd=123456";

这句是数据库的连接字符串
你至少应该改为

 string connString = "Data Source=HY-20141014UKZE\SQLEXPRESS;Initial Catalog=Financing;User ID=sa;Pwd=123456";

用户名和密码要根据你现在的数据库的用户名和密码来修改。

lzp_lrp
lzp_lrp   Ds   Rxr 2015.10.23 08:49

建议你把连接数据库的字符串放到配置文件里,这样比较容易修改,连接数据库可以参考如下

对于不同的.NET数据提供者,ADO.NET采用不同的Connection对象连接数据库。这些Connection对象为我们屏蔽了具体的实现细节,并提供了一种统一的实现方法。
Connection类有四种:SqlConnection,OleDbConnection,OdbcConnection和OracleConnection。
SqlConnection类的对象连接SQL Server数据库;OracleConnection 类的对象连接Oracle数据库;OleDbConnection类的对象连接支持OLE DB的数据库,如Access;而OdbcConnection类的对象连接任何支持ODBC的数据库。与数据库的所有通讯最终都是通过Connection对象来完成的。
(1)用SqlConnection连接SQL Server
加入命名空间:using System.Data.SqlClient;
连接数据库: string conString = "data source=IP地址; Database=数据库名;user id=用户名; password=密码";
SqlConnection myconnection = new SqlConnection(conString);
myconnection.open();
(2)用OracleConnection连接Oracle
加入命名空间:using System.Data.OracleClient;
连接数据库: string conString = "data source=IP地址; Database=数据库名;user id=用户名; password=密码";
OracleConnection myconnection = new OracleConnection(conString);
myconnection.open();
(3)用 MySqlConnection连接MySQL
在.NET中连接MySQL数据库有两种方法:MySQL Connector/ODBC 和 MySQL Connector/NET,ODBC连接器是符合ODBC标准的交互平台,是.NET访问MySQL数据库最好的选择。
首先,需要下载安装MySql-connector-net-5.1.5.Data.msi这个组件。如果是默认安装,则可以在C:\Program Files\MySQL\MySQL Connector Net 5.1.5\Binaries.NET2.0中找到MySql.Data.dll,将该文件复制到项目的bin目录下。并且在项目中添加引用MySql.Data.dll。实现代码如下:
加入命名空间:using MySql.Data.MySqlClient;
连接数据库: string conString = "server=IP地址; Database=数据库名;user id=用户名; password=密码";
MySqlConnection myconnection = new MySqlConnection(conString);
myconnection.open();
(4)用OleDbConnection连接各种数据源
由于数据源不同,相应的连接字符串也会不同。
加入命名空间:using System.Data.OleDb;
连接 SQL Server: string conString = "Provider=SQLOLEDB.1; Persist Security Info=False; user id=用户名; Database=数据库名; data source=COMPUTER; ";
OleDbConnection myconnection = new OleDbConnection(conString);
myconnection.open();
连接 Access: string conString = "Provider=Microsoft.Jet.OLEDB.4.0; data source=C:\Database1.mdb; Persist Security Info=False;";
OleDbConnection myconnection = new OleDbConnection(conString);
myconnection.open();
(也可以通过建立.udl文件来获得字符串)
连接 Oracle: string conString = "Provider=MSDAORA; user id=用户名; password=密码; data source=db; Persist Security Info=False;";
OleDbConnection myconnection = new OleDbConnection(conString);
myconnection.open();
(也可以通过OracleConnection连接)
注意:使用不同的Connection对象需要导入不同的命名空间。OleDbConnection的命名空间为System.Data.OleDb。SqlConnection的命名空间为System.Data.SqlClient。OracleConnection的命名空间为System.Data.OracleClinet。

我们就可以使用如下两种方式连接数据库,即采用集成的Windows验证和使用Sql Server身份验证进行数据库的登录。
1、集成的Windows身份验证语法范例
string constr = "server=.;database=myschool;integrated security=SSPI";
说明:程序代码中,设置了一个针对Sql Server数据库的连接字符串。其中server表示运行Sql Server的计算机名,由于程序和数据库系统是位于同一台计算机的,所以我们可以用.(或localhost)取代当前的计算机名。database表示所使用的数据库名(myschool)。由于我们希望采用集成的Windows验证方式,所以设置 integrated security为SSPI即可。
2、Sql Server 2005中的Windows身份验证模式如下:
string constr = "server=.;database=myschool;uid=sa;pwd=sa";
说明:程序代码中,采用了使用已知的用户名和密码验证进行数据库的登录。数据库连接字符串是不区分大小写的。uid为指定的数据库用户名,pwd为指定的用户口令。为了安全起见,一般不要在代码中包括用户名和口令,你可以采用前面的集成的Windows验证方式或者对Web.Config文件中的连接字符串加密的方式提高程序的安全性。
3、Sql Server 2005中的Sql Server身份验证模式如下:
string constr = "data source=.;initial catalog=myschool;user id=sa;pwd=sa";
说明:程序代码中data source 表示运行数据库对应的计算机名,initial catalog表示所使用的数据库名。uid为指定的数据库用户名,pwd为指定的用户口令。
4、Access数据库的连接字符串的形式如下:
string connectionString =@"provider=Microsoft.Jet.OLEDB.4.0;data source=c:\DataSource\myschool.mdb";

说明:程序代码中,通过专门针对Access数据库的OLE DB提供程序,实现数据库的连接。这使用的的OLE DB提供程序为Microsoft.Jet.OLEDB.4.0,并且数据库存放在c:\DataSource目录下,其数据库文件为myschool.mdb。

view plaincopy to clipboardprint?
string constr = "server=.;database=myschool;integrated security=SSPI";

//string constr = "server=.;database=myschool;uid=sa;pwd=sa";

//string constr = "data source=.;initial catalog=myschool;user id=sa;pwd=sa";

SqlConnection con = new SqlConnection(constr);

// con.ConnectionString = constr;

string sql = "select count(*) from grade";

SqlCommand com = new SqlCommand(sql,con);

try

{

con.Open();

MessageBox.Show("成功连接数据库");

int x = (int)com.ExecuteScalar();

MessageBox.Show(string.Format("成功读取{0},条记录", x));

}

catch (Exception)

{

 throw;  

}

finally

{

con.Close();

MessageBox.Show("成功关闭数据库连接", "提示信息", MessageBoxButtons.YesNoCancel);

}

5、Web.config 配置
在ASP.NET 2.0中,使用了一种在运行时解析为连接字符串值的新的声明性表达式语法,按名称引用数据库连接字符串。连接字符串本身存储在 Web.config 文件中的 <connectionStrings>配置节下面,以便易于在单个位置为应用程序中的所有页进行维护。
view plaincopy to clipboardprint?
<?xml version="1.0"?>

















我们也可以用下面的方式从配置文件直接读取数据库连接字符串。首先我们需要引用using System.Web.Configuration命名空间,该命名空间包含用于设置 ASP.NET 配置的类。string connectionString =ConfigurationManager.ConnectionStrings["myschool"].ConnectionString;

首先你应该区分Windows验证与Sql自身的验证的区别。

Windows验证就是SqlServer服务器使用Windows自带的验证系统,如果你指定SqlServer内Windows的一个组有访问的权限,那么加入此组的Windows用户都有访问数据库的权限。此验证有个缺点,就是如果不是在域模式下,无法加入远程计算机的用户,所以如果使用C/S方式写程序的话,使用Windows验证无法使本地计算机的Windows帐户访问远程数据库服务器。

Sql验证就简单多了,就是使用sqlserver的企业管理器中自己定义由Sql控制的用户,指定用户权限等。这个帐户信息是由SqlServer自己维护的,所以SqlServer更换计算机后信息不会丢失,不用重新设定。

所以如果你的项目使用在一个比较大的网络中,而且对安全要求比较高,那么应该建立域,使用Windows验证,而且要与系统管理员配合详细设定可以访问SqlServer的Windows帐户。如果使用一个小网络,而且此网络仅用来使用项目,对安全没有高要求,那么使用SqlServer验证,而且更新,升级等都方便。

Windows验证与SqlServer验证的数据库联接字符串是不同的。

Csdn user default icon
上传中...
上传图片
插入图片