レコードの挿入、更新、および削除にストアドプロシージャを使用し、プロシージャの実行または呼び出しにLINQを使用します。 [送信]ボタンをクリックすると、更新手順は実行されましたが、テーブルに変更はありません! fname_txt.textの代わりに "Jack"のような値を渡すと、動作し更新されます。 テキストボックスオブジェクトと引用符で囲まれた値の違いは何ですか?ここ は、コードは次のとおりです。コマンドが正しくてもテーブルが更新されない
protected void submit_Click(object sender, EventArgs e)
{
try
{
ZobLinqDataContext db = new ZobLinqDataContext();
string pasword = CryptorEngine.Encrypt(pass_txt.Text, true);
long uid = Convert.ToInt64(Request["uid"]);
db.pUpZDBUser(uid,
uname_txt.Text,
pasword,
fname_txt.Text.Trim(),
lname_txt.Text.Trim(),
modir.Checked,
voting.Checked,
Convert.ToInt32(Zarib_txt.Text),
false
);
db.SubmitChanges();
Response.Write(uname_txt);
}
finally
{
Session["sub"] = "1";
}
}
これは、更新PROCです:
USE [ZOBDB]
GO
/****** Object: StoredProcedure [dbo].[pUpZDBUser] Script Date: 04/11/2012 15:17:41 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
ALTER PROCEDURE [dbo].[pUpZDBUser]
@UID bigint,
@Uname nvarchar(100),
@Pass nvarchar(100),
@fname nvarchar(50),
@lname nvarchar(50),
@KU bit,
@KV bit,
@ZribV int,
@del bit
As
BEGIN TRANSACTION UpUser
Set NOCOUNT ON
UPDATE Users SET
[email protected],
[email protected],
[email protected],
[email protected],
[email protected],
[email protected],
[email protected],
[email protected]
where ([email protected])
--RollBack if Err
IF @@ERROR != 0 and @@ROWCOUNT != 1
BEGIN
declare @msg nvarchar(30)
set @msg = ' error '[email protected]
ROLLBACK
RAISERROR(@msg,16,1)
RETURN
END
COMMIT TRANSACTION UpUser
RETURN
pUpZDBUserメソッドに関連付けられたSQL PROCもコンテキストに投稿できますか? – StuartLC
これはASP Classicではなく.NETです。 –
私は応答のためにproc、tnxを追加しました。@nonnb – Behzad