简单的oracle存储过程

Jun 07, 2016 pm 03:38 PM
oracle による ストレージ 単純 プロセス

1、 oracle 存储过程以及 asp.NET 中调用存储过程,实现一个简单的登录功能,只是作为学习的,所以处理可能不太合理。 ① 在 PL/SQLDeveloper 中编写存储过程 新建 Procedures ,一个简单的登录检查存储过程代码如下: createorreplaceprocedureuser_login(s

1、oracle存储过程以及asp.NET中调用存储过程,实现一个简单的登录功能,只是作为学习的,所以处理可能不太合理。

① PL/SQL Developer中编写存储过程

新建Procedures,一个简单的登录检查存储过程代码如下:

create or replace procedure user_login(sname in nvarchar2 ,spassword in nvarchar2, ReturnValue out number)

 is --变量声明

  Rname nvarchar2(20);

  Rpassword nvarchar2(50);

begin 

 ReturnValue :=0; --赋初值

  select username into Rname from userinfo where username=sname;

  if Rname is not null then

    ReturnValue:=1;--用户名存在

    select userpassword into Rpassword from userinfo where username=sname and userpassword=spassword;

      if Rpassword is not null then

         ReturnValue:=2;--登陆成功              

      else ReturnValue:=1;--用户名存在,密码不正确

        return ;

        end if;

        else ReturnValue:=0;--用户不存在

          end if;    

    exception 

     when no_data_found then

       DBMS_OUTPUT.put_line('没有找到数据'); 

end;

② PL/SQL DeveloperSQL窗口中调用存储过程

declare --变量声明

        ReturnValue number(10);

begin

 user_login('faith','faith',ReturnValue);

   if ReturnValue=0 then

      DBMS_OUTPUT.put_line('不存在此用户');

     elsif ReturnValue=1 then

           DBMS_OUTPUT.put_line('存在用户,但密码不正确');     

     else 

       DBMS_OUTPUT.put_line('登录成功!!!');

     end if;

end;

③ VS2012中调用存储过程

OracleHelper.cs文件中:

public static void iRunProc(string procName, OracleParameter[] paras)

        {           

            OracleConnection conn=new OracleConnection(OracleHelper.strConn);

            if (conn.State == ConnectionState.Closed)

            {

                conn.Open();

            }

            OracleCommand cmd = new OracleCommand(procName, conn);

            cmd.CommandType = CommandType.StoredProcedure;

            if (paras != null)

            {

                for (int i = 0; i 

                {

                    OracleParameter parameter = paras[i];

                    cmd.Parameters.Add(parameter);

                }

            }

            int result = cmd.ExecuteNonQuery();

            cmd.ExecuteNonQuery();

        }

DAL层的webtestDal.cs文件中

 public static int loginByProc(string name,string password,string procName)

        {

            OracleParameter[] parameters ={

                                              new OracleParameter("sname", OracleType.NVarChar, 20),

                                              new OracleParameter("spassword", OracleType.NVarChar, 50),

                                              new OracleParameter("ReturnValue", OracleType.Number, 10)

                                         };

            parameters[0].Value = name;

            parameters[1].Value = password;

            //parameters[2].Value = 0;

            parameters[0].Direction = ParameterDirection.Input;

            parameters[1].Direction = ParameterDirection.Input;

            parameters[2].Direction = ParameterDirection.Output;

            try

            {

                OracleHelper.iRunProc(procName, parameters);

                int i = int.Parse(parameters[2].Value.ToString());

                return i;                  

            }

            catch (Exception e)

            {

                throw e;

            }

        }

BLL层的webtestBll.cs文件中

public static int loginByProc(string name, string password, string procName)

 {

     return webtestDal.loginByProc(name, password, procName);

}

在页面代码的登录按钮事件中

protected void btnSubmit_Click(object sender, EventArgs e)
        {
            string name = this.txtName.Text.Trim();
            string password = this.txtPassword.Text.Trim();
            //调用存储过程,判断是否登录成功
            if (webtestBll.loginByProc(name, password, "user_login")==2)//存储过程输出2表示登录成功
            {//登录成功,保存用户名和密码的cookie
                HttpCookie mycookie = new HttpCookie("loginCookie");
                mycookie.Values.Add("cname", name);
                mycookie.Values.Add("cpassword", password);
                mycookie.Expires = DateTime.Now.AddHours(4);//cookie的生命期
                Response.AppendCookie(mycookie);
                Response.Redirect("userinfo.aspx");
            }
            else if (webtestBll.loginByProc(name, password, "user_login") == 1)
            {
               // Response.Write("");
                RegisterClientScriptBlock("msg", "<script>alert(\"密码错误!\");</script>");
            }
            else
                RegisterClientScriptBlock("msg", "<script>alert(\"无法认证!\");</script>");
        }

2、登录之后,传递cookie

先获取登录界面的cookie值(代码如上)

将登录页面的cookie值传给跳转页面

protected void Page_Load(object sender, EventArgs e)
        {
            if (!IsPostBack)
            {
                DataTable dt = webtestBll.getAll();
                userInfoGrid.DataSource = dt;
                if (dt != null)
                    userInfoGrid.DataBind();
                
                HttpCookie mycookie = null;
                if (Request.Cookies.Get("loginCookie") != null)
                {//当用户登录了时,获取页面传来的cookie值
                    mycookie = Request.Cookies.Get("loginCookie");
                    this.txtLoginName.Text = mycookie.Values["cname"].ToString();
                    this.txtLoginPassword.Text = mycookie.Values["cpassword"].ToString();
                }
                else
                {//cookie过期或者没登录
                    Response.Redirect("userLogin.aspx?errorMsg=您还没登陆,请先登陆!");
                }
            }
        }

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

Oracleデータベースをインポートする方法 Oracleデータベースをインポートする方法 Apr 11, 2025 pm 08:06 PM

データインポート方法:1。SQLLOADERユーティリティを使用します。データファイルを準備し、制御ファイルを作成し、SQLLoaderを実行します。 2。IMP/EXPツールを使用します。データをエクスポートし、データをインポートします。ヒント:1。ビッグデータセットに推奨されるSQL*ローダー。 2。ターゲットテーブルが存在する必要があり、列定義が一致します。 3。インポート後、データの整合性を検証する必要があります。

Oracleの表空間サイズを確認する方法 Oracleの表空間サイズを確認する方法 Apr 11, 2025 pm 08:15 PM

Oracle Tablespaceサイズを照会するには、次の手順に従ってください。クエリを実行して、TableSpace名を決定します。DBA_TABLESPACesからTableSpace_Nameを選択します。クエリを実行してテーブルスペースのサイズをクエリします:sum(bytes)をtotal_size、sum(bytes_free)asavail_space、sum(bytes) - sum(bytes_free)as sum(bytes_free)as dba_data_files from tablespace_

Oracleでテーブルを作成する方法 Oracleでテーブルを作成する方法 Apr 11, 2025 pm 08:00 PM

Oracleテーブルの作成には、次の手順が含まれます。作成テーブルの構文を使用して、テーブル名、列名、データ型、制約、およびデフォルト値を指定します。テーブル名は簡潔で説明的である必要があり、30文字を超えてはなりません。列名は説明的でなければならず、データ型は列に保存されているデータ型を指定します。 NOT NULL制約により、列でnull値が許可されていないことが保証され、デフォルト句は列のデフォルト値を指定します。テーブルの一意の記録を識別する主要なキーの制約。外部キーの制約は、表の列が別のテーブルの主キーを指していることを指定します。主要なキー、一意の制約、デフォルト値を含むサンプルテーブル学生の作成を参照してください。

オラクルを開けない場合はどうすればよいですか オラクルを開けない場合はどうすればよいですか Apr 11, 2025 pm 10:06 PM

Oracleのソリューションを開くことはできません。1。データベースサービスを開始します。 2。リスナーを開始します。 3.ポートの競合を確認します。 4.環境変数を正しく設定します。 5.ファイアウォールまたはウイルス対策ソフトウェアが接続をブロックしないことを確認してください。 6.サーバーが閉じているかどうかを確認します。 7. RMANを使用して破損したファイルを回復します。 8。TNSサービス名が正しいかどうかを確認します。 9.ネットワーク接続を確認します。 10。Oracleソフトウェアを再インストールします。

Oracleで文字化けのコードを解決する方法 Oracleで文字化けのコードを解決する方法 Apr 11, 2025 pm 10:09 PM

Oracle Garbledの問題は、データベース文字セットをチェックしてデータと一致するようにすることで解決できます。データベースに一致するようにクライアント文字を設定します。データを変換するか、列文字セットを変更してデータベース文字セットに一致させます。 Unicode文字セットを使用して、マルチバイト文字セットを避けます。データベースとクライアントの言語設定が正しいことを確認してください。

テーブルフィールドをOracleに追加する方法 テーブルフィールドをOracleに追加する方法 Apr 11, 2025 pm 07:30 PM

ALTER TABLEステートメントを使用して、特定の構文は次のとおりです。ALTERTABLE TABLE_NAME add column_name data_type [constraint-clause]。 WHERE:table_nameはテーブル名、column_nameはフィールド名、data_typeはデータ型、制約条項はオプションの制約です。例:テーブルの従業員を変更すると、電子メールvarchar2(100)は、従業員テーブルに電子メールフィールドを追加します。

Oracleを再び追求する方法 Oracleを再び追求する方法 Apr 11, 2025 pm 07:33 PM

Oracleは複数の重複排除クエリメソッドを提供します。個別のキーワードは、各列の一意の値を返します。 Group by Clauseは、結果をグループ化し、各グループの非繰り返し値を返します。一意のキーワードは、一意の行のみを含むインデックスを作成するために使用され、インデックスをクエリすると自動的に重複排除が行われます。 row_number()関数は、一意の数値を割り当て、行1のみを含む結果をフィルタリングします。min()またはmax()関数は、数値列の非繰り返し値を返します。交差する演算子は、2つの結果セットの共通値を返します(複製なし)。

Oracleのインストールをアンインストールする方法は失敗しました Oracleのインストールをアンインストールする方法は失敗しました Apr 11, 2025 pm 08:24 PM

Oracleインストール障害のためのアンインストールメソッド:Oracleサービスを閉じ、Oracleプログラムファイルとレジストリキーを削除し、Oracle環境変数をアンインストールし、コンピューターを再起動します。アンインストールが失敗した場合、Oracle Universal Uninstallツールを使用して手動でアンインストールできます。

See all articles