Home Database Mysql Tutorial 简单的oracle存储过程

简单的oracle存储过程

Jun 07, 2016 pm 03:38 PM
oracle by storage Simple process

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=您还没登陆,请先登陆!");
                }
            }
        }

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
2 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: How To Get Giant Seeds
1 months ago By 尊渡假赌尊渡假赌尊渡假赌
Two Point Museum: All Exhibits And Where To Find Them
1 months ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

How long will Oracle database logs be kept? How long will Oracle database logs be kept? May 10, 2024 am 03:27 AM

The retention period of Oracle database logs depends on the log type and configuration, including: Redo logs: determined by the maximum size configured with the "LOG_ARCHIVE_DEST" parameter. Archived redo logs: Determined by the maximum size configured by the "DB_RECOVERY_FILE_DEST_SIZE" parameter. Online redo logs: not archived, lost when the database is restarted, and the retention period is consistent with the instance running time. Audit log: Configured by the "AUDIT_TRAIL" parameter, retained for 30 days by default.

Function to calculate the number of days between two dates in oracle Function to calculate the number of days between two dates in oracle May 08, 2024 pm 07:45 PM

The function in Oracle to calculate the number of days between two dates is DATEDIFF(). The specific usage is as follows: Specify the time interval unit: interval (such as day, month, year) Specify two date values: date1 and date2DATEDIFF(interval, date1, date2) Return the difference in days

The order of the oracle database startup steps is The order of the oracle database startup steps is May 10, 2024 am 01:48 AM

The Oracle database startup sequence is: 1. Check the preconditions; 2. Start the listener; 3. Start the database instance; 4. Wait for the database to open; 5. Connect to the database; 6. Verify the database status; 7. Enable the service (if necessary ); 8. Test the connection.

How much memory does oracle require? How much memory does oracle require? May 10, 2024 am 04:12 AM

The amount of memory required by Oracle depends on database size, activity level, and required performance level: for storing data buffers, index buffers, executing SQL statements, and managing the data dictionary cache. The exact amount is affected by database size, activity level, and required performance level. Best practices include setting the appropriate SGA size, sizing SGA components, using AMM, and monitoring memory usage.

How to use interval in oracle How to use interval in oracle May 08, 2024 pm 07:54 PM

The INTERVAL data type in Oracle is used to represent time intervals. The syntax is INTERVAL <precision> <unit>. You can use addition, subtraction, multiplication and division operations to operate INTERVAL, which is suitable for scenarios such as storing time data and calculating date differences.

How to see the number of occurrences of a certain character in Oracle How to see the number of occurrences of a certain character in Oracle May 09, 2024 pm 09:33 PM

To find the number of occurrences of a character in Oracle, perform the following steps: Get the total length of a string; Get the length of the substring in which a character occurs; Count the number of occurrences of a character by subtracting the substring length from the total length.

Oracle database server hardware configuration requirements Oracle database server hardware configuration requirements May 10, 2024 am 04:00 AM

Oracle database server hardware configuration requirements: Processor: multi-core, with a main frequency of at least 2.5 GHz. For large databases, 32 cores or more are recommended. Memory: At least 8GB for small databases, 16-64GB for medium sizes, up to 512GB or more for large databases or heavy workloads. Storage: SSD or NVMe disks, RAID arrays for redundancy and performance. Network: High-speed network (10GbE or higher), dedicated network card, low-latency network. Others: Stable power supply, redundant components, compatible operating system and software, heat dissipation and cooling system.

How to read dbf file in oracle How to read dbf file in oracle May 10, 2024 am 01:27 AM

Oracle can read dbf files through the following steps: create an external table and reference the dbf file; query the external table to retrieve data; import the data into the Oracle table.

See all articles