使用本地SQL server数据库的Visual Studio登录页面

本文关键字:Studio Visual 登录 数据库 SQL server | 更新日期: 2023-09-27 18:16:15

我正在创建一个visual studio项目,该项目使用本地SQL server数据库作为数据源,该数据库正在正常运行。

我需要为项目创建一个登录表单。

表单有一个用户名文本框和一个密码文本框,用户将填充他们的详细信息,然后点击'login'按钮,这需要执行select sql语句。

有关于如何做到这一点的参考吗?

我试过的代码如下。它抛出一个NullReferenceException在SqlDataReader dr = cmd.ExecuteReader();

如何解决nullreferenceexception?

谢谢!

private void button1_Click(object sender, EventArgs e)
        {
            try
            {
                SqlConnection con = new SqlConnection();
                con.ConnectionString = "Data Source=MARKO-PC''SQLEXPRESS;Initial     Catalog=IS2B_G8_FundMeDB;Integrated Security=True";
                con.Open();
                String sql = "Select * from APPLICANT where     applicant_ID_passport =@user AND password = @password";
                SqlCommand cmd = new SqlCommand(sql, con);
                cmd.Parameters.Add(new SqlParameter("@user", txtUserName.Text));
                cmd.Parameters.Add(new SqlParameter("@password",     txtPassword.Text));
                SqlDataReader dr = cmd.ExecuteReader();
                if (dr.HasRows == true)
                {
                    MessageBox.Show("Login Successful");
                }
                else
                {
                    MessageBox.Show("Login Failed");
                }
            }
            catch (SqlException sqle)
            {
                MessageBox.Show("Sql Exception");
            }

        }

使用本地SQL server数据库的Visual Studio登录页面

试试这个

string struser = txtUserName.Text;
string strpwd = txtPassword.Text;
 String sql = "Select * from APPLICANT where applicant_ID_passport=" + struser + " AND password = " + strpwd +"";
             SqlCommand cmd = new SqlCommand(sql, con);
             SqlDataReader dr = cmd.ExecuteReader();

您需要对使用ADO做一些研究。Net,特别是SQLCommand类。

然而,我将避免使用内联sql语句像上面一样,因为这会打开你的sql注入。不如使用参数化查询、存储过程或LINQ to SQL。