using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Data.SqlClient;

namespace ConsoleApplication1
{
    class Program
    {
        /// <summary>
        /// 执行TSQL语句
        /// </summary>
        /// <param name="str"></param>
        /// <returns></returns>
        public int zhixing(string str)
        {
            conn.Open();
            try
            {
                SqlCommand cmd = conn.CreateCommand();
                cmd.CommandText = str;
                int i = cmd.ExecuteNonQuery();
            conn.Close();
                return i;
            }
            catch (Exception ex) { Console.WriteLine(ex.Message);
            conn.Close(); ; }
        }
        static SqlConnection conn = new SqlConnection("server=.;database=Data0928;user=sa;pwd=123");

        /// <summary>
        /// 判断数据输入是否有误
        /// </summary>
        /// <param name="id">1:密码 2:昵称 3:性别 4:生日 5:民族 6:班级</param>
        /// <returns></returns>
        public string panduan(int id)
        {
            switch (id)
            {
                :
                    //密码
                    for (; ; )
                    {
                        Console.ForegroundColor = ConsoleColor.Yellow;
                        Console.Write("请输入密码:");
                        string napw = Console.ReadLine();
                        if (napw != "")
                            return napw;
                        else
                        {
                            Console.ForegroundColor = ConsoleColor.Red;
                            Console.WriteLine("该字段不能为空");
                        }
                    }
                :
                    //昵称
                    for (; ; )
                    {
                        Console.ForegroundColor = ConsoleColor.Yellow;
                        Console.Write("请输入昵称:");
                        string napw = Console.ReadLine();
                        if (napw != "")
                            return napw;
                        else
                        {
                            Console.ForegroundColor = ConsoleColor.Red;
                            Console.WriteLine("该字段不能为空");
                        }
                    }
                :
                    //性别
                    for (; ; )
                    {
                        Console.ForegroundColor = ConsoleColor.Yellow;
                        Console.Write("请输入性别:");
                        string sex = Console.ReadLine();
                        if (sex != "")
                        {
                            " || sex == "雄")
                                return "True";
                            " || sex == "雌")
                                return "False";
                            else
                            {
                                Console.ForegroundColor = ConsoleColor.Red;
                                Console.WriteLine("性别输入有误");
                            }
                        }
                        else
                        {
                            Console.ForegroundColor = ConsoleColor.Red;
                            Console.WriteLine("该字段不能为空");
                        }
                    }
                :
                    //生日
                    for (; ; )
                    {
                        Console.ForegroundColor = ConsoleColor.Yellow;
                        Console.Write("请输入生日:");
                        try   //尝试去做,如果有错,从错误的句直接跳转到catch
                        {
                            DateTime zhi = DateTime.Parse(Console.ReadLine());
                            return zhi.ToShortDateString();
                        }
                        catch  //只有错误的情况下
                        {
                            Console.ForegroundColor = ConsoleColor.Red;
                            Console.WriteLine("输入日期格式错误");
                        }
                    }
                :
                    //民族
                    for (; ; )
                    {
                        selectNation("Nation");
                        Console.ForegroundColor = ConsoleColor.Yellow;
                        Console.Write("请输入民族:N");
                        string nation = "";
                        int i = Convert.ToInt32(Console.ReadLine());
                        )
                            i = Math.Abs(i);
                        )
                        {
                            nation = ");

                            if (boselect("Nation", "NationCode", nation) || boselect("Nation", "NationName", nation))
                            {
                                return nation;
                            }
                            else
                            {
                                Console.ForegroundColor = ConsoleColor.Red;
                                Console.WriteLine("没有此民族编号或名称");
                            }
                        }
                        else
                        {
                            Console.ForegroundColor = ConsoleColor.Red;
                            Console.WriteLine("请输入数字1~999之间");
                        }
                    }
                :
                    //班级
                    for (; ; )
                    {
                        selectNation("Class");
                        Console.ForegroundColor = ConsoleColor.Yellow;
                        Console.Write("请输入班级:C");
                        string nation = "";
                        int i = Convert.ToInt32(Console.ReadLine());
                        )
                            i = Math.Abs(i);
                        )
                        {
                            nation = ");

                            if (boselect("Class", "ClassCode", nation) || boselect("Class", "ClassName", nation))
                            {
                                return nation;
                            }
                            else
                            {
                                Console.ForegroundColor = ConsoleColor.Red;
                                Console.WriteLine("没有此班级编号或名称");
                            }
                        }
                        else
                        {
                            Console.ForegroundColor = ConsoleColor.Red;
                            Console.WriteLine("请输入数字1~999之间");
                        }
                    }
                default: break;
            }
            return "";
        }

        /// <summary>
        /// 判断要执行的操作
        /// </summary>
        /// <param name="id">操作编号</param>
        public void caozuo(int id)
        {
            switch (id)
            {
                :
                    //查询select
                    while (true)
                    {
                        Console.ForegroundColor = ConsoleColor.Yellow;
                        Console.Write("请输入要查看的表名:");
                        string tabname = Console.ReadLine();
                        if (tabname != "")
                        {
                            Console.Write("请输入条件列名:");
                            string cluame = Console.ReadLine();
                            if (tabname != "")
                            {
                                Console.Write("请输入条件:");
                                string UserName = Console.ReadLine();
                                if (tabname != "")
                                {
                                    if (select(tabname, cluame, UserName))
                                    {
                                        break;
                                    }
                                }
                            }
                        }
                        else
                        {
                            Console.ForegroundColor = ConsoleColor.Red;
                            Console.WriteLine("该字段不能为空");
                        }
                    }
                    break;
                :
                    //插入
                    while (true)
                    {
                        Console.ForegroundColor = ConsoleColor.Yellow;
                        Console.Write("请输入要插入的用户名:");
                        string UserName = Console.ReadLine();
                        if (!boselect("Users", "UserName", UserName))
                        {
                            );
                            );
                            );
                            );
                            );
                            );
                            )
                            {
                                Console.WriteLine("成了"); break;
                            }
                            else
                            {
                                Console.ForegroundColor = ConsoleColor.Red;
                                Console.WriteLine("没成");
                            }
                        }
                        else
                        {
                            Console.ForegroundColor = ConsoleColor.Red;
                            Console.WriteLine("此用户名以存在请更改。");
                        }
                    }
                    break;
                :
                    //删除
                    while (true)
                    {
                        Console.ForegroundColor = ConsoleColor.Yellow;
                        Console.Write("请输入要删除的用户名:");
                        string UserName = Console.ReadLine();
                        if (boselect("Users", "UserName", UserName))
                        {
                            )
                            {
                                Console.WriteLine("成了"); break;
                            }
                            else
                            {
                                Console.ForegroundColor = ConsoleColor.Red;
                                Console.WriteLine("没成");
                            }
                        }
                        else
                        {
                            Console.ForegroundColor = ConsoleColor.Red;
                            Console.WriteLine("此用户名不存在请更改。");
                        }
                    }
                    break;
                :
                    //修改
                    while (true)
                    {
                        Console.ForegroundColor = ConsoleColor.Yellow;
                        Console.Write("请输入要修改的用户名:");
                        string UserName = Console.ReadLine();
                        if (boselect("Users", "UserName", UserName))
                        {
                            );
                            );
                            );
                            );
                            );
                            );
                            )
                            {
                                Console.WriteLine("成了"); break;
                            }
                            else
                            {
                                Console.ForegroundColor = ConsoleColor.Red;
                                Console.WriteLine("没成");
                            }
                        }
                        else
                        {
                            Console.ForegroundColor = ConsoleColor.Red;
                            Console.WriteLine("此用户名不存在请更改。");
                        }
                    }
                    break;
                default:
                    break;
            }
        }

        /// <summary>
        /// 查询语句
        /// </summary>
        /// <param name="tabname">要查询的表名</param>
        /// <param name="cluame">要查询的条件列</param>
        /// <param name="UserName">条件</param>
        /// <returns></returns>
        public bool select(string tabname, string cluame, string UserName)
        {
            try
            {
                SqlCommand cmd = conn.CreateCommand();
                Console.ForegroundColor = ConsoleColor.Blue;
                if (tabname == "Users" || tabname == "users")
                {
                    conn.Open();
                    cmd.CommandText = "SELECT ids,UserName,[PassWord],NickName,Sex,Birthday,NationName as Nation,ClassName AS Class FROM Users,Class,Nation WHERE Nation=NationCode AND Class=ClassCode AND " + cluame + "='" + UserName + "'";

                    SqlDataReader dr = cmd.ExecuteReader();
                    Console.WriteLine("┌──────────────────────────────────┐");
                    Console.WriteLine("│ ID\t用户名\t密码\t昵称\t性别\t生日\t\t民族\t班级 │");
                    if (dr.HasRows)
                    {
                        while (dr.Read())
                        {
                            Console.WriteLine("│ {0}\t{1}\t{2}\t{3}\t{4}\t{5}\t{6}\t{7} │", dr["ids"], dr["username"], dr["PassWord"], dr["NickName"], dr["Sex"], Convert.ToDateTime(dr["Birthday"]).ToShortDateString(), dr["Nation"], dr["class"]);
                        }
                        Console.WriteLine("└──────────────────────────────────┘");
                        conn.Close();
                        return true;
                    }
                    else
                    {
                        Console.WriteLine("│──────────────────────────────────│");
                        Console.WriteLine("│─────────────未查到任何数据──────────────│");
                        Console.WriteLine("│──────────────────────────────────│");
                        Console.WriteLine("└──────────────────────────────────┘");
                        conn.Close();
                        return false;
                    }
                }
                else
                {
                    cmd.CommandText = "SELECT * FROM " + tabname + " where " + cluame + "='" + UserName + "'";
                    SqlDataReader dr = cmd.ExecuteReader();
                    Console.WriteLine("┌───────────┐");
                    Console.WriteLine("│\t编号\t名称\t│");
                    conn.Open();
                    if (dr.HasRows)
                    {
                        while (dr.Read())
                        {
                            Console.WriteLine(], dr[]);
                        }
                        Console.WriteLine("└───────────┘");
                        conn.Close();
                        return true;
                    }
                    else
                    {
                        Console.WriteLine("│───────────│");
                        Console.WriteLine("│──未查到任何数据──│");
                        Console.WriteLine("│───────────│");
                        Console.WriteLine("└───────────┘");
                        conn.Close();
                        return false;
                    }
                }
            }
            catch
            {
                Console.ForegroundColor = ConsoleColor.Red;
                Console.WriteLine("表名、列名、数据输入有误");
                return false;
            }
        }

        /// <summary>
        /// 判断UserName是否存在
        /// </summary>
        /// <param name="tabname">表名</param>
        /// <param name="UserName">用户名</param>
        /// <returns></returns>
        public bool boselect(string tabname, string cluame, string UserName)
        {
            conn.Open();
            SqlCommand cmd = conn.CreateCommand();
            cmd.CommandText = "SELECT * FROM " + tabname + " where "+cluame+"='" + UserName + "'";
            SqlDataReader dr = cmd.ExecuteReader();
            if (dr.HasRows)
            {
                conn.Close();
                return true;
            }
            else
            {
                conn.Close();
                return false;
            }
        }

        /// <summary>
        /// 打印所有用户数据
        /// </summary>
        public void selectall()
        {
            SqlCommand cmd = conn.CreateCommand();
            Console.ForegroundColor = ConsoleColor.Blue;
            Console.WriteLine("┌──────────────────────────────────┐");
            Console.WriteLine("│ ID\t用户名\t密码\t昵称\t性别\t生日\t\t民族\t班级 │");
            conn.Open();
            cmd.CommandText = "SELECT ids,UserName,[PassWord],NickName,Sex,Birthday,NationName as Nation,ClassName AS Class FROM Users,Class,Nation WHERE Nation=NationCode AND Class=ClassCode";
            SqlDataReader dr = cmd.ExecuteReader();
            if (dr.HasRows)
            {
                while (dr.Read())
                {
                    Console.WriteLine("│ {0}\t{1}\t{2}\t{3}\t{4}\t{5}\t{6}\t{7} │", dr["ids"], dr["username"], dr["PassWord"], dr["NickName"], dr["Sex"], Convert.ToDateTime(dr["Birthday"]).ToShortDateString(), dr["Nation"], dr["class"]);
                }
            }
            else
            {
                Console.WriteLine("│──────────────────────────────────│");
                Console.WriteLine("│─────────────未查到任何数据──────────────│");
                Console.WriteLine("│──────────────────────────────────│");
            }
            conn.Close();
            Console.WriteLine("└──────────────────────────────────┘");
        }

        /// <summary>
        /// 打印所有民族与代码
        /// </summary>
        public void selectNation(string tabname)
        {
            SqlCommand cmd = conn.CreateCommand();
            Console.ForegroundColor = ConsoleColor.Blue;
            Console.WriteLine("┌───────────┐");
            Console.WriteLine("│\t编号\t名称\t│");
            conn.Open();
            cmd.CommandText = "SELECT * FROM " + tabname;
            SqlDataReader dr = cmd.ExecuteReader();
            if (dr.HasRows)
            {
                while (dr.Read())
                {
                    Console.WriteLine(], dr[]);
                }
            }
            else
            {
                Console.WriteLine("│───────────│");
                Console.WriteLine("│──未查到任何数据──│");
                Console.WriteLine("│───────────│");
            }
            conn.Close();
            Console.WriteLine("└───────────┘");

        }

        static void Main(string[] args)
        {
            Program pr = new Program();
            SqlCommand cmd = conn.CreateCommand();

            //打印所有人的数据
            pr.selectall();
            while (true)
            {
                Console.ForegroundColor = ConsoleColor.Yellow;
                Console.WriteLine("1.查询");
                Console.WriteLine("2.插入");
                Console.WriteLine("3.删除");
                Console.WriteLine("4.修改");
                Console.Write("请选择要执行的操作:");
                try
                {
                    int biao = Convert.ToInt32(Console.ReadLine());
                     && biao < )
                    {
                        pr.caozuo(biao);
                        Console.ForegroundColor = ConsoleColor.Yellow;
                        Console.Write("请输入任意键继续_");
                        Console.ReadKey();
                        Console.Clear();
                        pr.selectall();
                    }
                    else
                    {
                        Console.Clear();
                        pr.selectall();
                        Console.ForegroundColor = ConsoleColor.Yellow;
                        Console.WriteLine("请输入1~4进行选择");
                    }
                }
                catch
                {
                    Console.Clear();
                    pr.selectall();
                    Console.WriteLine("请输入数字1~4进行选择");
                }
            }
        }
    }
}

代码

干净到爆,可以点啊,点点试试

2016年11月28日--ADO.Net 查、插、删、改 小练习的更多相关文章

  1. 2016年11月28日--ADO.Net 增、删、改、查

    数据访问 对应命名空间:System.Data.SqlClient; SqlConnection:连接对象SqlCommand:命令对象SqlDataReader:读取器对象 CommandText: ...

  2. 2016年11月28日 星期一 --出埃及记 Exodus 20:19

    2016年11月28日 星期一 --出埃及记 Exodus 20:19 and said to Moses, "Speak to us yourself and we will listen ...

  3. 2016年12月28日 星期三 --出埃及记 Exodus 21:23

    2016年12月28日 星期三 --出埃及记 Exodus 21:23 But if there is serious injury, you are to take life for life,若有 ...

  4. 2016年11月30日 星期三 --出埃及记 Exodus 20:21

    2016年11月30日 星期三 --出埃及记 Exodus 20:21 The people remained at a distance, while Moses approached the th ...

  5. 2016年11月29日 星期二 --出埃及记 Exodus 20:20

    2016年11月29日 星期二 --出埃及记 Exodus 20:20 Moses said to the people, "Do not be afraid. God has come t ...

  6. 2016年11月27日 星期日 --出埃及记 Exodus 20:18

    2016年11月27日 星期日 --出埃及记 Exodus 20:18 When the people saw the thunder and lightning and heard the trum ...

  7. 2016年11月26日 星期六 --出埃及记 Exodus 20:17

    2016年11月26日 星期六 --出埃及记 Exodus 20:17 "You shall not covet your neighbor's house. You shall not c ...

  8. 2016年11月25日 星期五 --出埃及记 Exodus 20:16

    2016年11月25日 星期五 --出埃及记 Exodus 20:16 "You shall not give false testimony against your neighbor.不 ...

  9. 2016年11月24日 星期四 --出埃及记 Exodus 20:15

    2016年11月24日 星期四 --出埃及记 Exodus 20:15 "You shall not steal.不可偷盗.

随机推荐

  1. 百度数据可视化图表套件echart实战

    最近我一直在做数据可视化的前端工作,我用的最多的绘图工具是d3.d3有点像photoshop,功能很强大,例子也很多,但是学习成本也不低,做项目是需要较大人力投入的.3月底由在亚马逊工作的同学介绍下使 ...

  2. SQLserver中用convert函数转换日期格式

    SQLserver中用convert函数转换日期格式 2008-01-23 15:47 SQLserver中用convert函数转换日期格式2008-01-15 15:51SQLserver中用con ...

  3. java并发编程学习: 守护线程(Daemon Thread)

    在正式理解这个概念前,先把 守护线程 与 守护进程 这二个极其相似的说法区分开,守护进程通常是为了防止某些应用因各种意外原因退出,而在后台独立运行的系统服务或应用程序. 比如:我们开发了一个邮件发送程 ...

  4. Editplus常用快捷键

    EditPlus 快捷键的使用 如果一个来你们公司面试程序员,连Ctrl + C 和Ctrl + V 都不用,而是使用“选中文本”→ 鼠标右键 → [复制],然后再鼠标右键→ [粘贴].你会不会录用他 ...

  5. Oracle系列——开发中奇葩问题你遇到几个(一)

    前言:在使用oracle数据进行开发的时候有没有经常出现一些很奇怪.很纳闷.很无厘头的问题呢.下面是本人使用oracle一段时间遇到的问题小节,在此做个记录,方便以后再遇到类似的问题能快速解决.如果你 ...

  6. CSS3系列之3D制作

    一.序 博主最近这些天,突发奇想的想研究一下CSS3的东西,从而提升一下CSS的能力,在学习的过程中发现其实CSS3是一个挺复杂的东西,深入的研究,你可能会涉及到初中的光学理论来帮助理解一些概念,同时 ...

  7. 解决Centos/Redhat,命令不存在

    [root@26 ~]# lsb_release                    #不存在-bash: lsb_release: command not found    [root@26 ~] ...

  8. XUtils框架之初步探索

    Xutils分为四大模块. BitmapUtils  DBUtils ViewUtils HttpUtils

  9. Mysql索引PRIMARY、NORMAL、UNIQUE、FULLTEXT 区别和使用场合

    索引 数据库的索引就像一本书的目录,能够加快数据库的查询速度. MYSQL索引有四种PRIMARY.INDEX.UNIQUE.FULLTEXT, 其中PRIMARY.INDEX.UNIQUE是一类,F ...

  10. C#文本写入文件,追加写入文件

    写入文件和这个对象 StreamWriter using (StreamWriter fs = new StreamWriter(path, true)) { fs.WriteLine(strLog) ...