Avatar billede mema Nybegynder
15. maj 2006 - 21:56 Der er 4 kommentarer og
1 løsning

Visning af ID-value efter sending af en formular

Jeg har en asp.net formular, som sender nogle data til en Access-database. Det, som jeg gerne vil, er at vise ID-nummeret (i Access - Autonummerering) som tildeles automatisk efter submitting af denne formular for netop denne person som har sendt formularen. Dette kan naturligvis ske på en ny side (en slag bekræftelse).
Min formular (codebehind) ser sådan ud:
-----
using System;
using System.Collections;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Web;
using System.Web.SessionState;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.HtmlControls;
using System.Data.OleDb;

namespace Jobbors
{
/// Summary description for opret.
   
public class opret : System.Web.UI.Page
{
protected System.Web.UI.WebControls.Label lblFejl;
protected System.Web.UI.WebControls.Button Button1;
protected System.Web.UI.WebControls.TextBox Navn;
protected System.Web.UI.WebControls.TextBox Email;
   
private void Page_Load(object sender, System.EventArgs e)
{
// Put user code to initialize the page here
}

#region Web Form Designer generated code
override protected void OnInit(EventArgs e)
{
// CODEGEN: This call is required by the ASP.NET Web Form Designer.
//
InitializeComponent();
base.OnInit(e);
}
/// Required method for Designer support - do not modify
/// the contents of this method with the code editor.
private void InitializeComponent()
{
this.Button1.Click += new System.EventHandler(this.Button1_Click);
this.Load += new System.EventHandler(this.Page_Load);
}
#endregion

private void Button1_Click(object sender, System.EventArgs e)
{
Page.Validate();
if (Page.IsValid)
{
try
{
string  strInsert;
OleDbCommand cmdInsert;

string connStr = "Provider=Microsoft.Jet.OLEDB.4.0; Data Source=" + MapPath("fpdb/Person.mdb");
OleDbConnection conn = new OleDbConnection(connStr);
strInsert = "INSERT INTO pers (Navn,Email) Values (@Navn, @Email)";
cmdInsert = new OleDbCommand( strInsert, conn );
cmdInsert.Parameters.Add( "@Navn", Navn.Text );
cmdInsert.Parameters.Add( "@Email", Email.Text );
                   
conn.Open();
cmdInsert.ExecuteNonQuery();
conn.Close();                Response.Redirect("oversigt.aspx");
}
catch
{
lblFejl.Text = "<font color=red>Der er sket en fejl:</font><br>" +
"Du har muligvis indtastet for mange tegn. Prøv at reducere dem.";
}
finally
{
Response.Write("");
}
}return;
}
}
}
Avatar billede websam Nybegynder
16. maj 2006 - 11:10 #1
Det gør du med en Select @@Identity lige efter din indsættelse i databasen så kan du retunere ideet den nye record har genereret ;o)

/Websam
Avatar billede mema Nybegynder
16. maj 2006 - 16:32 #2
Jeg tak. Men jeg har ikke nogen konkret viden om hvordan. Jeg bruger asp.net 1.1 og Databasen er som nævnt en Access database.
Avatar billede mema Nybegynder
19. maj 2006 - 15:24 #3
Det har ikke været nemt at finde vejen til løsningen. Men du gav mig den retning!
Send venligst et svar.
Avatar billede websam Nybegynder
20. maj 2006 - 10:50 #4
svar
Avatar billede mema Nybegynder
20. maj 2006 - 16:20 #5
Tak
Avatar billede Ny bruger Nybegynder

Din løsning...

Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] Web- og emailadresser omdannes automatisk til links. Der sættes "nofollow" på alle links.

Loading billede Opret Preview
Kategori
IT-kurser om Microsoft 365, sikkerhed, personlig vækst, udvikling, digital markedsføring, grafisk design, SAP og forretningsanalyse.

Log ind eller opret profil

Hov!

For at kunne deltage på Computerworld Eksperten skal du være logget ind.

Det er heldigvis nemt at oprette en bruger: Det tager to minutter og du kan vælge at bruge enten e-mail, Facebook eller Google som login.

Du kan også logge ind via nedenstående tjenester