黑马程序员—课程总结之ADO.Net手机归属地

---------------------- Windows Phone 7手机开发.Net培训、期待与您交流! ----------------------

(一)配置文件

1.添加一个配置文件

2.在配置文件中的connectionStrings中add一个connectionString

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
<connectionStrings>
<add name="ConnStr" connectionString="Data Source=VVP-PC\JADAM;Initial Catalog=master;Integrated Security=true"/>
</connectionStrings>
</configuration>

3.在项目中添加引用system.configuration,然后using system.configuration;

4.在实例化SqlConnection对象中使用配置文件中的连接字符串

using (SqlConnection conn = new SqlConnetion(ConfigurationManager.ConnectionStrings["ConnStr"].ConnectionString))

 (二)导入数据

private void btnImport_Click(object sender, EventArgs e)
        {
            //打开文件夹对话框
            FolderBrowserDialog dlg = new FolderBrowserDialog();
            
            //如果用户没有选择文件夹,则跳出当前函数
            if (dlg.ShowDialog() != DialogResult.OK)
            {
                return;
            }
            


            
            //导入数据前先清空表中的内容
            using (SqlConnection conn = new SqlConnection(connStr))
            {
                conn.Open();
                using (SqlCommand cmd = conn.CreateCommand())
                {
                    cmd.CommandText = "DELETE FROM T_Numbers";
                    cmd.ExecuteNonQuery();
                }
            }

            //得到用户选择的文件夹路径
            string path = dlg.SelectedPath;

            //取文件夹下的所有TXT文件的文件名(包括所选文件夹下的子文件夹)
            string[] files = Directory.GetFiles(path, "*.txt", SearchOption.AllDirectories);

            using (SqlConnection conn = new SqlConnection(connStr))
            {
                conn.Open();
                using (SqlCommand cmd = conn.CreateCommand())
                {
                    //遍历每个文件
                    foreach (string file in files)
                    {
                        //读取文件名(无扩展名)
                        string 省运营商 = Path.GetFileNameWithoutExtension(file);

                        //使用ReadAllLines的重载方法,选择默认编码参数防止出现乱码
                        string[] lines = File.ReadAllLines(file, Encoding.Default);

                        //遍历每行数据
                        foreach (string line in lines)
                        {
                            string[] strs = line.Split('-');
                            string startNum = strs[0];
                            string endNum = strs[1];
                            string city = strs[2];

                            cmd.CommandText = "INSERT INTO T_Numbers (StartNum,EndNum,City) VALUES (@StartNum,@EndNum,@City)";
                            
                            //每次循环先清除上次循环中添加的参数
                            cmd.Parameters.Clear();
                            
                            cmd.Parameters.Add(new SqlParameter("StartNum", startNum));
                            cmd.Parameters.Add(new SqlParameter("EndNum", endNum));
                            cmd.Parameters.Add(new SqlParameter("City", 省运营商 + city));
                            cmd.ExecuteNonQuery();
                        }
                    }
                }//End Using SqlCommand
            }//End Using SqlConnection

            MessageBox.Show("导入完成!");
        }

编码方式:在记事本点“另存为”后,可以看到编码方式

File.ReadAllLine()方法默认是UTF-8编码,可重载

(三)查询

        private void btnSelect_Click(object sender, EventArgs e)
        {
            using (SqlConnection conn = new SqlConnection(connStr))
            {
                conn.Open();
                using (SqlCommand cmd = conn.CreateCommand())
                {
                    cmd.CommandText = "SELECT City FROM T_Numbers WHERE @PhoneNum>=StartNum and @PhoneNum<=EndNum";
                    cmd.Parameters.Add("PhoneNum", txtPhoneNum.Text);
                    string result=Convert.ToString(cmd.ExecuteScalar());
                    MessageBox.Show("您所查询的号码"+txtPhoneNum.Text+"属于"+result);
                }

            }

当查询时输入一段错误的号码,在数据库中查询不到结果时,可以处理一下cmd.ExecuteScalar()返回值为null的情况。

(四)一段神奇代码

放在Main()方法最开始

            string dataDir = AppDomain.CurrentDomain.BaseDirectory;
            if (dataDir.EndsWith(@"\bin\Debug\")
                || dataDir.EndsWith(@"\bin\Release"))
            {
                dataDir = System.IO.Directory.GetParent(dataDir).Parent.Parent.FullName;
                AppDomain.CurrentDomain.SetData("DataDirectory", dataDir);
            }

---------------------- Windows Phone 7手机开发.Net培训、期待与您交流! ----------------------

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值