原文发布时间为:2008-07-24 —— 来源于本人的百度文章 [由搬家工具导入]

总算把这起步的路走了.
首先来总结一下进行数据库编程的全过程,这里用的是SQL SERVER
(1)建立SqlConnection对象以连接数据库
SqlConnection mysqlconnection=new SqlConnection("Server=.\\SQLEXPRESS;
               database=yourdatabase;uid=sa;pwd=sa");

(2)建立SqlCommand对象
SqlCommand mysqlcommand=mysqlconnection.CreateCommand();

(3)设置SqlCommand对象的CommandText属性
mysqlcommand.CommandText="SELECT * FROM youydatabasetablename";

(4)打开SqlConnection对象
mysqlconnection.open();

(5)运行SELECT语句
SqlDataReader mysqldatareader=mysqlcommand.ExecuteReader();

(6)用SqlDataReader对象读行
mysqldatareader.Read();

(7)显示SqlDataReader对象中的数值
yourtextbox.Text=mysqldatareader["ID"].ToString();
//ID是你数据库中的一项列名

(8)关闭SqlDataReader对象
mysqldatareader.Close();

(9)关闭SqlConnection对象
mysqlconnection.Close();

下面把过程呈现出来.

1]在我的程序中用的是SQL,所以在程序头前加上
using System.Data.SqlClient;

2]在Form1中加入应有的控件,用于显示数据.

3]申请变量
        static private int m = 1; //显示每条记录
        static private int k;      //得到记录条数
        SqlCommand mysqlcommand;
        SqlConnection mysqlconnection;

4]连接数据库,注意这里的连接字符串,用的是安全类型.
         try
         {           
                mysqlconnection = new SqlConnection("server=localhost;
                           Integrated Security=True;Database=myfriends");
                mysqlcommand = mysqlconnection.CreateCommand();
                                   //得到记录条数
                mysqlcommand.CommandText = "SELECT COUNT(*) FROM Friends";
                mysqlconnection.Open();
                k = (int)mysqlcommand.ExecuteScalar();

                GetData(1);
            }
            catch (SqlException ex)
            {
                MessageBox.Show("A SqlException was thrown,Number = " +
                               ex.Number +     //错误号
                               ex.Message +    //错误描述字符串
                               ex.StackTrace); //抛出异常的类名和方法名字符串
            }

5]如果数据库中有多条记录就要逐条显示
在逐条显示的按钮事件中:
            m += 1;//下一条索引值
            if (m > k)
            {
                MessageBox.Show("最后一条!将显示第一条记录!", "信息提示");
                m = 1;
            }
            this.hisname.Text = "";   //要显示下条,当然先清空
            this.hissex.Text = "";
            this.hisadress.Text = "";
            this.hisbirthday.Text = "";

            GetData(m);//显示下第数据

6]在显示数据中用到显示下一条函数;
private void GetData(int i)
{
            mysqlcommand.CommandText = "SELECT ID,Name,Sex,"+
                            "birthday,address FROM Friends WHERE ID="+i;
            SqlDataReader mysqldatareader = mysqlcommand.ExecuteReader();
            mysqldatareader.Read();

            this.hisname.Text = mysqldatareader["Name"].ToString();
            this.hissex.Text = mysqldatareader["Sex"].ToString();
            this.hisadress.Text = mysqldatareader["Address"].ToString();
            this.hisbirthday.Text = mysqldatareader["Birthday"].ToString();

            mysqldatareader.Close();
}

希望对正阅读的你有所帮助!
也以此鼓励自己不断学习!

C#连接数据库SQL(2005)的更多相关文章

  1. SQL 2005远程连接是出错(provider: SQL 网络接口, error: 28 - 服务器不支持请求的协议

    SQL 2005远程连接是出错(provider: SQL 网络接口, error: 28 - 服务器不支持请求的协议 sql远程连接服务器网络sql serversqlserver 解决方法:在服务 ...

  2. SQL 2005批量插入数据的二种方法

    SQL 2005批量插入数据的二种方法 Posted on 2010-07-22 18:13 moss_tan_jun 阅读(2635) 评论(2) 编辑 收藏 在SQL Server 中插入一条数据 ...

  3. SQL 2005中char、nchar、varchar、ntext and nvarchar(max)的区别

    原文地址 MS SQL大值数据类型varchar(max).nvarchar(max).varbinary(max) 在MS SQL2005及以上的版本中,加入大值数据类型(varchar(max). ...

  4. SQL 2005 中查询或执行另外的数据库操作的方法

    原文:SQL 2005 中查询或执行另外的数据库操作的方法 摘要: 如果,你想在一台数据库服务器上,查询另一个台数据服务器的数据该如何做呢?如果,你想在同一台数据服务器上,在不同的数据库之间查询数据, ...

  5. SQL 2005 安装数据库镜像教程

    最近在搞在SQL 2005安装数据库镜像,中间遇到不少的错误,在此归纳总结,以方便有需要的朋友参考. 直接上脚本,主机部分: ---修改数据库为完整恢复模式USE master;ALTER DATAB ...

  6. SQL 2005/2008 连接SQL 2000报18456错误

    在看文章前,你先看看下面这两个问题,考考你对MSSMS工具的掌握情况: 1: SQL 2005/2008 能连接 SQL 2000数据库服务器吗? 2: SQL 2000 能连接SQL 2005/20 ...

  7. SQL Server:查看数据库用户权限(SQL 2005)

    1. 查看 SQL 2005 用户所属数据库角色 use yourdb go select DbRole = g.name, MemberName = u.name, MemberSID = u.si ...

  8. windows 10 安装 sql 2005 安装失败

    windows 10 安装 sql 2005 安装失败 网上的方法记录: 安装中无法启动需要先用sp4的补丁文件sqlos.dll,sqlservr.exe 替换D:\Program Files (x ...

  9. SQL 2005示例库(转载)

    sql2005数据库实例 从网上找还得麻烦,转了过来,点击就可以下载! 在学习SQL2005中离开不了SQL2005示例数据库,AdventureWorks数据库下载安装,,northwind数据库下 ...

随机推荐

  1. 测试 code style

    c++ #include <iostream> int main(int argc, char *argv[]) { /* An annoying "Hello World&qu ...

  2. [51nod] 1301 集合异或和

    考虑不限制xor{Y}>xor{X} 考虑n=m的情况,每个数i∈[1,n]可以被分配到X集合或Y集合,或不分配 设f[S]表示{X} xor {Y} == S的方案数 有f[S]+=2*f[S ...

  3. Golang Json测试

    结构体是谷歌搜索API package main import ( "encoding/json" "fmt" "io/ioutil" &q ...

  4. Makefile基础(三)

    第一章:C语言之Makefile基础(一) 第二章:C语言之Makefile基础(二) 再来看一个简单的例子: [root@localhost linux_c]# cat Makefile foo = ...

  5. 29、在android中采用动画方案来弹出窗口

    1.自定义style 2.使用方法: buttonWhat.setOnClickListener(new OnClickListener() { @Override public void onCli ...

  6. Selenium WebDriver- 隐式等待

    隐式等待是只要有一个元素在设置的时间内没有找到,就会报超时 隐式等待是一个全局的设置,只要放在找东西语句的前面,它后面的找东西的语句都会默认等待设置的时间(这里是10秒),这是死等,除非立刻找到了,5 ...

  7. 【整理】python中re的match、search、findall、finditer区别

    match 从首字母开始开始匹配,string如果包含pattern子串,则匹配成功,返回Match对象,失败则返回None,若要完全匹配,pattern要以$结尾. search 若string中包 ...

  8. Spring 4.3.11.RELEASE文档阅读(二):Core Technologies_IOC

    在看这部分内容的时候,想了一些问题: 容器: 1,什么是容器 用来包装或装载物品的贮存器 2,容器能做什么 包装或装载物品 3,为什么需要容器 为什么要使用集装箱?如果没有容器会是什么样? 4,常见的 ...

  9. API生命周期第二阶段——设计:如何设计API(基于swagger进行说明)

    题外话 在新的项目中,推行了swagger用于对API的设计.以期待解决我们上篇博客中说到了一些现象,提升工作效率.那么,结合到当时和全项目组成员做培训,以及后续的给主要应用者做培训,以及当初自己接触 ...

  10. 剪枝的定义&&hdu1010

    半年前在POJ上遇到过一次剪枝的题目,那时觉得剪枝好神秘...今天在网上查了半天资料,终于还是摸索到了一点知识,但是相关资料并不多,在我看来,剪枝是技巧,而不是方法,也就是说,可能一点实用的小技巧,让 ...