如果用户名不存在" INSERT INTO"否则[更新" (显示信息) [英] If username not exist "INSERT INTO" Else "UPDATE" (display info)

查看:222
本文介绍了如果用户名不存在" INSERT INTO"否则[更新" (显示信息)的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

这是我的表:

<table>
    <tr><td><b>Utilizador:</b></td><td><asp:Label ID="username" runat="server"></asp:Label></td></tr> 
    <tr><td><b>Telefone da Empresa:</b></td><td><asp:TextBox ID="empresa" runat="server" MaxLength="13"></asp:TextBox> (Exemplo: +351234925xxx)</td></tr>
    <tr><td><b>2º Telefone:</b></td><td><asp:TextBox ID="empresa2" runat="server" MaxLength="4"></asp:TextBox> (Exemplo: xxxx)</td></tr>
    <tr><td><b>Telemóvel:</b></td><td><asp:TextBox ID="telemovel" runat="server" MaxLength="13"></asp:TextBox> (Exemplo: +3519xxxxxxxx)</td></tr>
    <tr><td colspan="2"><asp:Label ID="lblInfo" runat="server" Font-Bold="True"></asp:Label></td></tr>
    <tr><td><asp:Button ID="cmdSave" runat="server" Text="Guardar" onclick="cmdSave_Click" /></td><td></td></tr>
    </table>

我想验证如果的用户名在数据库中告诉我答案的更新 ELSE 插入

i want verify IF username exist in database show me the answers to update ELSE insert into

这是我的code后面为止。它给的插入

this is my code behind so far. it's to insert into

    public partial class _Default : System.Web.UI.Page
    {
        protected void Page_Load(object sender, EventArgs e)
        {
            username.Text = "[" + HttpContext.Current.User.Identity.Name + "]"; 
        }

        protected void cmdSave_Click(object sender, EventArgs e)
        {
            string sFilePath = Server.MapPath("Database3.accdb");
            OleDbConnection Conn = new OleDbConnection("Provider=Microsoft.ACE.OLEDB.12.0;Data Source=" + sFilePath + ";Persist Security Info=False;");
            string insertCmd = "INSERT INTO colaborador(Empresa,Empresa2,Telemovel,username) VALUES (@Empresa,@Empresa2,@Telemovel,@username)";
            using (Conn)
            {
                Conn.Open();
                OleDbCommand myCommand = new OleDbCommand(insertCmd, Conn);
                myCommand.Parameters.AddWithValue("@Empresa", empresa.Text);
                myCommand.Parameters.AddWithValue("@Empresa2", empresa2.Text);
                myCommand.Parameters.AddWithValue("@Telemovel", telemovel.Text);
                myCommand.Parameters.AddWithValue("@username", HttpContext.Current.User.Identity.Name);            
                Response.Write(" ");
                myCommand.ExecuteNonQuery(); 
                lblInfo.Text = "Dados guardados!";
                lblInfo.ForeColor = System.Drawing.Color.Green;
            }
        }
}

我的目的就是之前回答我的表显示的回答问题[或显示一个消息,说用户已经回答如果在我的数据库不存在,则显示该表到现场。
它的驾驶我疯狂无法这样的事情

my purpose is before answer my table show the answered questions [or display an message saying "User already answered"] if not exist in my database then display the table to field. It's driving me crazy can't to such thing

推荐答案

这可以这样实现,

  SqlCommand objcmd = new SqlCommand("SELECT 1 from Table WHERE Username=@NAME" , objsqlconn);//get rows if username exists
cmd.Parameters.Add("@NAME", SqlDbType.NVarChar,20).Value = Master_product_txt.Text;   
objsqlconn.Open();
    readr = SelectCommand.ExecuteReader();

    if (!readr.HasRows) 
    {
    `// write Code to insert values
    }`
    else
    {
      //write code to retrieve values and update          
    }

主编的code由@阿ツ

Edited the code as pointed out by @ A ツ

这篇关于如果用户名不存在&QUOT; INSERT INTO&QUOT;否则[更新&QUOT; (显示信息)的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
相关文章
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆