平凡的KTV後臺,不平凡的KTV數據

来源:http://www.cnblogs.com/bdpsc/archive/2016/02/05/5182736.html
-Advertisement-
Play Games

之前就是說過“一個項目有很多重要的步驟以及功能”,那我們現在就來看看對於KTV項目來說;後臺是處於什麼樣的重要作用! 首先就得瞭解KTV後臺的一些功能了: 1.歌曲管理 、歌手管理 、設置資源路徑 2.新增歌手、歌手查詢、新增歌曲、歌曲查詢、更改歌曲路徑以及退出點歌系統 一.後臺登錄界面 01.判斷


    之前就是說過“一個項目有很多重要的步驟以及功能”,那我們現在就來看看對於KTV項目來說;後臺是處於什麼樣的重要作用!

    首先就得瞭解KTV後臺的一些功能了:

    1.歌曲管理 、歌手管理 、設置資源路徑

    2.新增歌手、歌手查詢、新增歌曲、歌曲查詢、更改歌曲路徑以及退出點歌系統

   

    一.後臺登錄界面

  

 

 01.判斷登錄

 }
        //登陸
        private void btnlogin_Click(object sender, EventArgs e)
        {
            SqlConnection con = new SqlConnection(DBHelp.str);
            string sql = "select count(1) from admin_info where admin_name='" + txtuser.Text + "' and admin_pwd='" + txtpwd.Text + "'";
            SqlCommand cmd = new SqlCommand(sql, con);
            try
            {
                con.Open();
                int count = Convert.ToInt32(cmd.ExecuteScalar());
                if (count > 0)
                {
                    this.Hide();
                    FrmMain frm = new FrmMain();
                    frm.Show();
                }
            }
            catch (Exception)
            {

                MessageBox.Show("失敗");
            }
            finally
            {
                con.Close();
}
}

 

    二.主界面窗體

  

    01.新增歌手

   

   

     001.添加歌手

  //添加
        public void SongInfoAdd()
        { 
           string name = txtname.Text;//歌手姓名
            string type = "";//類別
            if (ramale.Checked)
            {
                type = "";
            }
            else if (rafemale.Checked)
            {
                type = "";
            }
            else if (raguoup.Checked)
            {
                type = "組合";
            }
            int id = Convert.ToInt32(cbotype.SelectedValue);//類型            
            string description = txtdescrp.Text;//描述
            SqlConnection con = new SqlConnection(DBHelp.str);
            string sql = "insert into singer_info values('" + name + "'," + id + ",'" + type + "','" + fileName + "','" + description + "')";
            SqlCommand cmd = new SqlCommand(sql,con);
            try
            {
                con.Open();
                int count = cmd.ExecuteNonQuery();
                if (count > 0)
                {
                    File.Copy(fullName, Commod.DBsongurl + "\\" + fileName, true);
                    MessageBox.Show("歌手添加成功");
                }
                else
                {
                    MessageBox.Show("歌手添加失敗");
                }
            }
            catch (Exception)
            {

                MessageBox.Show("歌手載入失敗"); ;
            }
            finally
            {
                con.Close();//關閉
            }
        }

 

    002.添加圖片

  string fileName = "";
        string fullName = "";

        private void btnView_Click(object sender, EventArgs e)
        {

            //瀏覽
            if (this.ofdlist.ShowDialog() == DialogResult.OK)
            {

                fileName = this.ofdlist.SafeFileName; // 文件名
                fullName = this.ofdlist.FileName;
                picphoto.Image = Image.FromFile(fullName);
                txtdescrp.Text = fullName;
            }
        }

 

   02.查詢歌手

 

 

 

 

 

 

001.按歌手條件查詢

 private void btnselect_Click(object sender, EventArgs e)
        {
            //判定用歌手名或歌手類型查詢
            if (txtname.Text != ""&&cbotype.Text=="請選擇")
            {
                //歌手名
                string sql = @"select singer_name,singertype_name,singer_gender,singer_description
                                from singer_type,singer_info
                    where singer_type.singertype_id=singer_info.singertype_id 
                    and singer_name like '%" + txtname.Text + "%'";
                Selectsong(sql);

            }
            else if (txtname.Text=="")
            {
                //類型
                string sql = @"select singer_name,singertype_name,singer_gender,singer_description
                                from singer_type,singer_info
                    where singer_type.singertype_id=singer_info.singertype_id 
                    and singertype_name like '%" + cbotype.Text + "%'";
                Selectsong(sql);
            }
            else
            {
                string sql = @"select singer_name,singertype_name,singer_gender,singer_description
                                from singer_type,singer_info
                    where singer_type.singertype_id=singer_info.singertype_id 
                    and singer_name like '%" + txtname.Text + "%' and singertype_name like '" + cbotype.Text +"'";
                Selectsong(sql);
            }
           
        }

 

 002.給下拉框賦值

 

 //下拉框
        public void Singerselect()
        {
            string str = DBHelp.str;
            //連接資料庫
            SqlConnection con = new SqlConnection(str);
            string sql = "select singertype_id,singertype_name from singer_type";
            //數據集和資料庫連接
            SqlDataAdapter da = new SqlDataAdapter(sql, con);
            DataSet ds = new DataSet();
            try
            {
                da.Fill(ds);
                //綁定數據源
                DataTable dt = ds.Tables[0];
                DataRow dr = dt.NewRow();
                //給該行賦值
                dr[0] = -1;
                dr[1] = "請選擇";
                dt.Rows.InsertAt(dr, 0);
                cbotype.DataSource = ds.Tables[0];
                //下拉框顯示值
                cbotype.DisplayMember = "singertype_name";
                //下拉框隱藏值
                cbotype.ValueMember = "singertype_id";
            }
            catch (Exception)
            {
                MessageBox.Show("載入失敗!");
            }
            finally
            {
                con.Close();
            }
        }

 

   003.右鍵修改和刪除並及時刷新

  

 

  代碼:

 //修改
        private void tsupdate_Click(object sender, EventArgs e)
        {
            string uname = dgvlist.SelectedRows[0].Cells[0].Value.ToString();
            this.Hide();
            frmAddSinger frm = new frmAddSinger();
            frm.Text = "修改歌手信息";
            frm.uname = uname;
            frm.Show();
        }
        //刪除
        private void tsdelete_Click(object sender, EventArgs e)
        {
            string names = dgvlist.SelectedRows[0].Cells[0].Value.ToString();
            string sql = "delete singer_info where singer_name='" + names + "'";
            Selectsong(sql);
            string sql1 = @"select singer_name,singertype_name,singer_gender,singer_description
                            from singer_type,singer_info
                        where singer_type.singertype_id=singer_info.singertype_id";
            Selectsong(sql1);
        }

 

   修改歌手

  

 

  修改代碼:

 //修改
        public void Update()
        {
            int songid = Convert.ToInt32(cbotype.SelectedValue);
            int num = txtname.Text.Length;
            SqlConnection con = new SqlConnection(DBHelp.str);
            //singer_id, singer_name, singertype_id, singer_gender, singer_photo_url, singer_description
            string sql = @"update singer_info set singer_name='" + txtname.Text + "',singer_gender='" + ch + "',singer_photo_url='" + fileName +
                         "',singertype_id=" + type + ",singer_description='"+txtdescrp.Text+"' where singer_name ='" + uname + "'";
            SqlCommand cmd = new SqlCommand(sql, con);
            try
            {
                con.Open();
                int count = cmd.ExecuteNonQuery();
                if (count > 0)
                {
                    MessageBox.Show("修改成功");
                }
            }
            catch (Exception)
            {

                MessageBox.Show("載入失敗"); ;
            }
            finally
            {
                con.Close();
            }
        }

 

  修改與添加的關鍵判斷代碼:

  private void btnadd_Click(object sender, EventArgs e)
        {
            if (this.Text=="修改歌手信息")
            {
                Update();//修改
            }
            else
            {
                SongInfoAdd();//保存功能
            }
            
        }
  private void frmAddSinger_Load(object sender, EventArgs e)
        {
            Singerselect(); //預設查詢代碼
            Commod.DBsongurl=OldLoadWays();
            if (this.Text=="修改歌手信息")
            {
                btnadd.Text = "修改";
                //MessageBox.Show(uname);
                Load_information();
            }
            else
            {
                this.Text = "編輯歌手信息";
                btnadd.Text = "保存";
            }
        }

 

 03.新增歌曲

 

  001.查詢代碼

  //查詢
        private void btnsearch_Click(object sender, EventArgs e)
        {
            //歌手

            FrmSelectSinger frm = new FrmSelectSinger();
            frm.Show();
            this.Close();
        } 


   //歌手添加 
            string singer = dgvlist.SelectedRows[0].Cells[0].Value.ToString();
           
            FrmAdd frm = new FrmAdd();
            frm.name = singer;
            frm.Show();
            this.Close();

 

 

 002.自動形成縮寫代碼

 

public class Song_ab
    {   
        private static int[] pyValue = new int[]
    {
    -20319,-20317,-20304,-20295,-20292,-20283,-20265,-20257,-20242,-20230,-20051,-20036,
    -20032,-20026,-20002,-19990,-19986,-19982,-19976,-19805,-19784,-19775,-19774,-19763,
    -19756,-19751,-19746,-19741,-19739,-19728,-19725,-19715,-19540,-19531,-19525,-19515,
    -19500,-19484,-19479,-19467,-19289,-19288,-19281,-19275,-19270,-19263,-19261,-19249,
    -19243,-19242,-19238,-19235,-19227,-19224,-19218,-19212,-19038,-19023,-19018,-19006,
    -19003,-18996,-18977,-18961,-18952,-18783,-18774,-18773,-18763,-18756,-18741,-18735,
    -18731,-18722,-18710,-18697,-18696,-18526,-18518,-18501,-18490,-18478,-18463,-18448,
    -18447,-18446,-18239,-18237,-18231,-18220,-18211,-18201,-18184,-18183, -18181,-18012,
    -17997,-17988,-17970,-17964,-17961,-17950,-17947,-17931,-17928,-17922,-17759,-17752,
    -17733,-17730,-17721,-17703,-17701,-17697,-17692,-17683,-17676,-17496,-17487,-17482,
    -17468,-17454,-17433,-17427,-17417,-17202,-17185,-16983,-16970,-16942,-16915,-16733,
    -16708,-16706,-16689,-16664,-16657,-16647,-16474,-16470,-16465,-16459,-16452,-16448,
    -16433,-16429,-16427,-16423,-16419,-16412,-16407,-16403,-16401,-16393,-16220,-16216,
    -16212,-16205,-16202,-16187,-16180,-16171,-16169,-16158,-16155,-15959,-15958,-15944,
    -15933,-15920,-15915,-15903,-15889,-15878,-15707,-15701,-15681,-15667,-15661,-15659,
    -15652,-15640,-15631,-15625,-15454,-15448,-15436,-15435,-15419,-15416,-15408,-15394,
    -15385,-15377,-15375,-15369,-15363,-15362,-15183,-15180,-15165,-15158,-15153,-15150,
    -15149,-15144,-15143,-15141,-15140,-15139,-15128,-15121,-15119,-15117,-15110,-15109,
    -14941,-14937,-14933,-14930,-14929,-14928,-14926,-14922,-14921,-14914,-14908,-14902,
    -14894,-14889,-14882,-14873,-14871,-14857,-14678,-14674,-14670,-14668,-14663,-14654,
    -14645,-14630,-14594,-14429,-14407,-14399,-14384,-14379,-14368,-14355,-14353,-14345,
    -14170,-14159,-14151,-14149,-14145,-14140,-14137,-14135,-14125,-14123,-14122,-14112,
    -14109,-14099,-14097,-14094,-14092,-14090,-14087,-14083,-13917,-13914,-13910,-13907,
    -13906,-13905,-13896,-13894,-13878,-13870,-13859,-13847,-13831,-13658,-13611,-13601,
    -13406,-13404,-13400,-13398,-13395,-13391,-13387,-13383,-13367,-13359,-13356,-13343,
    -13340,-13329,-13326,-13318,-13147,-13138,-13120,-13107,-13096,-13095,-13091,-13076,
    -13068,-13063,-13060,-12888,-12875,-12871,-12860,-12858,-12852,-12849,-12838,-12831,
    -12829,-12812,-12802,-12607,-12597,-12594,-12585,-12556,-12359,-12346,-12320,-12300,
    -12120,-12099,-12089,-12074,-12067,-12058,-12039,-11867,-11861,-11847,-11831,-11798,
    -11781,-11604,-11589,-11536,-11358,-11340,-11339,-11324,-11303,-11097,-11077,-11067,
    -11055,-11052,-11045,-11041,-11038,-11024,-11020,-11019,-11018,-11014,-10838,-10832,
    -10815,-10800,-10790,-10780,-10764,-10587,-10544,-10533,-10519,-10331,-10329,-10328,
    -10322,-10315,-10309,-10307,-10296,-10281,-10274,-10270,-10262,-10260,-10256,-10254
    };
        private static string[] pyName = new string[]
    {
    "A","Ai","An","Ang","Ao","Ba","Bai","Ban","Bang","Bao","Bei","Ben",
    "Beng","Bi","Bian","Biao","Bie","Bin","Bing","Bo","Bu","Ba","Cai","Can",
    "Cang","Cao","Ce","Ceng","Cha","Chai","Chan","Chang","Chao","Che","Chen","Cheng",
    "Chi","Chong","Chou","Chu","Chuai","Chuan","Chuang","Chui","Chun","Chuo","Ci","Cong",
    "Cou","Cu","Cuan","Cui","Cun","Cuo","Da","Dai","Dan","Dang","Dao","De",
    "Deng","Di","Dian","Diao","Die","Ding","Diu","Dong","Dou","Du","Duan","Dui",
    "Dun","Duo","E","En","Er","Fa","Fan","Fang","Fei","Fen","Feng","Fo",
    "Fou","Fu","Ga","Gai","Gan","Gang","Gao","Ge","Gei","Gen","Geng","Gong",
    "Gou","Gu","Gua","Guai","Guan","Guang","Gui","Gun","Guo","Ha","Hai","Han",
    "Hang","Hao","He","Hei","Hen","Heng","Hong","Hou","Hu","Hua","Huai","Huan",
    "Huang","Hui","Hun","Huo","Ji","Jia","Jian","Jiang","Jiao","Jie","Jin","Jing",
    "Jiong","Jiu","Ju","Juan","Jue","Jun","Ka","Kai","Kan

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • Request failed: unacceptable content type: text/plain(AFNetworking) = 在使用AFNetworking遇到如下問題,已解決。。。 Error Domain=com.alamofire.error.serialization.resp
  • 分類:C#、Android、VS2015;創建日期:2016-02-06 第4章 UI設計基礎 第3章雖然通過百度地圖應用展示了你可能感興趣的內容,但是,如果你是一個初學者,一開始就看懂和理解代碼可能會非常費勁。為瞭解決此問題,從這一章開始,本模塊將從最基本的內容講起,帶你逐步進入用C#進行Andr...
  • 實在太忙,靈魂有香氣的女子這個App,斷斷續續開發了1個多月了,前後臺自己獨立完成, 由於接觸swift沒多久,還屬於新手行列,不熟悉,希望大家給出意見, 根據意見,完善後將於近期將考慮開放swift版本的源代碼。 下載方式: 1、靈魂有香氣的女子這個App :https://itunes.appl
  • 分類:C#、Android、VS2015、百度地圖應用; 創建日期:2016-02-04 一、簡介 POI(Point of Interest),中文可以翻譯為“興趣點”。在地理信息系統中,一個POI可以是一棟房子、一個商鋪、一個郵筒、一個公交站等。 1、POI檢索 百度地圖SDK提供三種類型的PO
  • 微軟一統 Windows 10 的音頻和 MIDI API 微軟在夏季NAMM上的A3E大會上做了主題演講,他們對Windows 10的音頻和MIDI API都做了新的規劃,開發者針對Windows 10開發的應用在手機、平板、桌面電腦、Raspberry Pi 2上也可以運行。 微軟之前在音頻方面
  • 基本概念 塊設備(blockdevice) --- 是一種具有一定結構的隨機存取設備,對這種設備的讀寫是按塊進行的,他使用緩衝區來存放暫時的數據,待條件成熟後,從緩存一次性寫入設備或者從設備一次性讀到緩衝區。 字元設備(Character device) ---是一個順序的數據流設備,對這種設備的讀
  • 如果沒記錯的話,阿裡雲ECS上的Ubuntu也是LTS版本。 如果還在使用較舊版本的Ubuntu,或者是Ubuntu LTS,那麼我們是很難體驗新版gcc的。怎麼辦呢? 我們或許可以自己去編譯用舊版本的gcc去編譯新版本,但比較繁瑣而且坑點較多。如果有現成的包就好啦! 原來,在toolchain/t
  • 丙申年把真假美猴王囚禁在容器中跑 ASP.NET Core 1.0¶警告您當前查看的頁面是未經授權的轉載! 如果當前版本排版錯誤,請前往查看最新版本:http://www.cnblogs.com/qin-nz/p/aspnetcore-run-on-mono-in-year-of-monkey.ht...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...