使用oracle数据库根据年份和日期重置C#中的自动编号

时间:2015-05-22 01:25:43

标签: c# oracle autonumber

我在C#中自动生成数字自动创建。此样本 PPP-150500001 PPP-150500002 => PPP - 是一个永远不会改变的字符串, 15 是一年, 05 是一个日期,而 00001 是自动的生成数字。 如何在获得 PPP-160100001 之类的新年后重置自动编号。

这是我的方法:

public void NomerUrut()
    {
        long hitung;
        string urut;
        OracleCommand cmd = new OracleCommand();
        OracleDataReader dr;
        cmd.CommandText = @"SELECT NOPERMOHONAN FROM PERMOHONAN WHERE NOPERMOHONAN IN (SELECT MAX(NOPERMOHONAN) 
                            FROM PERMOHONAN) ORDER BY NOPERMOHONAN DESC";
        cmd.Connection = koneksi_manual.con;
        koneksi_manual.con.Open(); //open connection
        dr = cmd.ExecuteReader();
        dr.Read();
        if (dr.HasRows)
        {
            hitung = Convert.ToInt64(dr[0].ToString().Substring(dr["NOPERMOHONAN"].ToString().Length - 5, 5)) + 1;
            string joinstr = "00000" + hitung;
            DateTime dt = DateTime.Now; // take years and date in autonumber
            urut = "PPP-" + dt.ToString("yy") + dt.ToString("MM") + joinstr.Substring(joinstr.Length - 5, 5); 
            //it will show PPP-150500002, PPP-150500003, etc
            //how can i reset this autonumber after get new years like PPP-160100001
        }
        else
        {
            urut = "PPP-150500001"; // first form load will display this default autonumber
        }
        dr.Close();
        txtNoPermohonan.Text = urut; //display auto generate number in a textbox
        koneksi_manual.con.Close(); //close connection
    }

解决。

我有这个问题的更新,我可以使用另一个查询来解决我的问题。我可以每年重置它.. 这是我的更新代码:

public static string GenerateKodeUrut()
    {
        string nomor = "";
        string date = DateTime.Now.ToString("yyyy/MM/dd").Substring(2, 2);
        DateTime dt = DateTime.Now;

        OracleCommand cmd = new OracleCommand();
        OracleDataReader dr;
        cmd.CommandText = (@"SELECT NOPERMOHONAN from PERMOHONAN 
                             where substr(NOPERMOHONAN, 5,2) ='" + date + "' ORDER BY cast(substr(NOPERMOHONAN, 9,5) as number) DESC");
        cmd.Connection = koneksi_manual.con;
        dr = cmd.ExecuteReader();
        dr.Read();
        if (dr.HasRows)
        {
            string nmrTerakhir = (dr["NOPERMOHONAN"]).ToString().Remove(0, 8);
            nomor = "PPP-" + date + dt.ToString("MM") + (Convert.ToInt32(nmrTerakhir) + 1).ToString("0000#");
        }
        else
        {
            nomor = "PPP-" + date + dt.ToString("MM") + "00001";
        }
        return nomor;
    }

1 个答案:

答案 0 :(得分:1)

你可以在你的数据库中做一个检查它&&你的约会。

我希望代码能给你我的想法

  <body ng-app="myApp" ng-controller="test" ng-class="{'navOpen':toggle, 'icon':toggle, 'wrapper': toggle}" ng-click="toggle=!toggle">