1、为DataTable添加列

(1)添加列

DataTable  tbl = ds.Tables.Add("User");

DataColumn col =tbl.Columns.Add("UserID",typeof(int));

col.AllowDBNull = false;

col.MaxLength = 6;

col.Unique = true;

tbl.PrimaryKey = new DataColumn[]{tbl.Columns["UserID"]};

当设置主键时,AllowDBNull自动设置为False;

(2)添加自增列

DataSet ds = new DataSet();

DataTable tbl = ds.Tables.Add("User");

DataColumn col = tbl.Columns.Add("UserID",typeof(int));

col.AutoIncrement = true;

col.AutoIncrementSeed = -1;

col.AutoIncrementStep = -1;

col.ReadOnly = true;

2、修改DataTable中的数据

(1)添加数据行

DataRow row = ds.Tables["User"].NewRow();

row["UserID"] = "123456";

ds.Tables["User"].Rows.Add(row);

object[] aValues ={"123456","张三"}

da.Tables["User"].LoadDataRow(aValues,false);

(2)修改当前行

修改行的内容 Datast并不会自动修改数据库中相应的内容,而是要使用SqlDataAdapter对象的Update方法来提交修改。

//查找UserID为123456的用户,有则修改

DataRow   User;

User = ds.Tables["UserID"].Rows.Find("123456");

if(User == null)

//没有查找客户

else

{

User.BeginEdit();

User["UserName"] ="王五";

User.EndEdit();

}

obejct[]  User ={null,”王五”} ;//null表示不修改该列的数据

DataRow rowUser;

rowUser = ds.Tables["UserID"].Rows.Find("123456");

rowUser.ItemArray = User;

(3)处理行中的空值

A:查看是否为空

DataRow rowUser;

rowUser = ds.Tables["UserID"].Rows.Find("123456");

if(rowUser.IsNull("Address"))

Console.WriteLine("Address is Null");

else

Console.WriteLine("Address is not Null");

B:赋予空值

rowUser["Address"] = DBNull.Value;

(4)删除行

DataRow rowUser;

rowUser = ds.Tables["UserID"].Rows.Find("123456");

rowUser.Delete();

(5)清除DataRow

A:

DataRow rowUser;

rowUser = ds.Tables["UserID"].Rows.Find("123456");

rowUser.ItemArray = aUser;

da.Tables["User"].Remove(rowUser);

B:

ds.Tables["User"].RemoveAt(intIndex);

3、实例

using System;

using System.Collections.Generic;

using System.Text;

using System.Data.SqlClient;

using System.Data;

namespace sqlconnection1

{

class Program

{

private void SQLConnectionF(string source, string select)

{

//创建连接

SqlConnection con = new SqlConnection(source);

SqlDataAdapter adapt = new SqlDataAdapter(select,con);

try

{

con.Open();

Console.WriteLine("connection is successful!");

}

catch (Exception e)

{

Console.WriteLine("connection error is :{0}", e.ToString());

}

SqlCommandBuilder mybuilder = new SqlCommandBuilder(adapt);

//创建DataSet

DataSet ds = new DataSet();

//将数据添加到DataSet中

adapt.Fill(ds,"mytest");

//取出mytest表各列名

Console.WriteLine("{0,-15} {1,-10} {2,-10}",ds.Tables["mytest"].Columns[0],

ds.Tables["mytest"].Columns[1], ds.Tables["mytest"].Columns[2],

ds.Tables["mytest"].Columns[3], ds.Tables["mytest"].Columns[4]);

//输出DataSet中的所有数据

Console.WriteLine("before up data");

foreach (DataRow row in ds.Tables["mytest"].Rows)

{

Console.WriteLine("{0,-35} {1,-10} {2,-10} {3}",row[0] ,

row[1] , row[2] , row[3]);

}

//将第一行的第四列的值修改为123

DataRow rows1 = ds.Tables["mytest"].Rows[0];

rows1[3] = "123";

//删除该行

rows1.Delete();

//插入一行

DataRow newrow = ds.Tables["mytest"].NewRow();

newrow[0] = "mmm";

newrow[1] = 36;

newrow[2] = "aaa";

newrow[3] = 222;

ds.Tables["mytest"].Rows.Add(newrow);

//在DataSet中查找数据

DataColumn[] keys = new DataColumn[2];

keys[0] = ds.Tables["mytest"].Columns["name"];

keys[1] = ds.Tables["mytest"].Columns["number"];

//keys[1] = ds.Tables["mytest"].Columns ["type"];

ds.Tables["mytest"].PrimaryKey = keys;

DataRow findrow = ds.Tables["mytest"].Rows.Find("rrr");

if (findrow != null)

{

Console.WriteLine("{0}is find in tables",findrow);

//delete the row

Console.WriteLine("removing the rows ........");

findrow.Delete();

}

//用DataSet中的数据更新表

adapt.Update(ds,"mytest");

//输出DataSet中的所有数据

Console.WriteLine("after up data");

foreach (DataRow row in ds.Tables["mytest"].Rows)

{

Console.WriteLine("{0,-15} {1,-10} {2,-10} {3}", row[0],

row[1], row[2], row[3]);

}

Console.ReadLine();

con.Close();

}

static void Main(string[] args)

{

string sou = "server=duanyf\\SQLEXPRESS;" + "Initial Catalog=master;" + "UID = sa;" + "Password = dyf123";

string sel = "SELECT name,number,type,low,high From dbo.spt_values WHERE number=36";

Program sqlcon = new Program();

sqlcon.SQLConnectionF(sou, sel);

}

}

}

【转自】http://www.cnblogs.com/hulang/archive/2011/01/11/1932567.html

dataset 用法(2)的更多相关文章

  1. DataSet用法详细 转

    DataSet用法详细 转 DataSet用法详细 一.特点介绍 1.处理脱机数据,在多层应用程序中很有用. 2.可以在任何时候查看DataSet中任意行的内容,允许修改查询结果的方法. 3.处理分级 ...

  2. DataSet用法详细

    转自:http://www.cnblogs.com/zeroone/archive/2012/06/08/2541299.html DataSet用法详细 一.特点介绍 1.处理脱机数据,在多层应用程 ...

  3. dataset 用法(3)

    ReadXml 提供了只将数据或同时将数据和架构从 XML 文档读入 DataSet 的方式(若要同时读数据和架构,请使用包括 mode 参数的 ReadXML 重载之一,并将其值设置为 ReadSc ...

  4. dataset 用法(1)

    DataSet是表和列结构在内存中的表示方式,DataSet支持多表.表间关系.数据约束等,和关系数据库的模型基本一致.(本质上是微型的数据库.包含一组DataTable对象和DataTable之间的 ...

  5. DATASET()用法

    DataSet是ADO.NET的中心概念.可以把DataSet当成内存中的数据库,DataSet是不依赖于数据库的独立数据集合.所谓独立,就是说,即使断开数据链路,或者关闭数据库,DataSet依然是 ...

  6. js 控制 class 类名(classList) 和 自定义属性(dataset)

    classList 用法: const div = document.querySelector('div') div.classList.add('myclass') // 添加类名 div.cla ...

  7. tensorflow学习笔记--dataset使用,创建自己的数据集

    数据读入需求 我们在训练模型参数时想要从训练数据集中一次取出一小批数据(比如50条.100条)做梯度下降,不断地分批取出数据直到损失函数基本不再减小并且在训练集上的正确率足够高,取出的n条数据还要是预 ...

  8. 【转】如何在TensorFlow中高效使用数据集

    本文主要记录tensorflow一个比较好用的API:Dataset,feed-dict 是向 TensorFlow 传递信息最慢的方式,应该尽量避免使用.向模型提供数据的正确方式是使用输入管道,这样 ...

  9. dataset 和DataTable的用法

    以下包含了这两种不同属性的用法: foreach (DataRow dr in dataset.Tables[0].Rows)            { if (i != 0 && l ...

随机推荐

  1. 图像处理库的比较:OpenCV,FreeImage,CImg,CxImage

    1.对OpenCV 的印象:功能十分的强大,而且支持目前先进的图像处理技术,体系十分完善,操作手册很详细,手册首先给大家补计算机视觉的知识,几乎涵盖了近10年内的主流算法: 然后将图像格式和矩阵运算, ...

  2. php set env

    SYSTEM WARNING: 'date_default_timezone_get(): It is not safe to rely on the system's timezone settin ...

  3. Mysql中Key与Index的区别

    mysql的key和index多少有点令人迷惑,这实际上考察对数据库体系结构的了解的. 1 key 是数据库的物理结构,它包含两层意义,一是约束(偏重于约束和规范数据库的结构完整性),二是索引(辅助查 ...

  4. jQuery学习笔记(一)——基础选择器、过滤选择器、表单选择器

    $()就是jQuery中的函数,它的功能是获得()中指定的标签元素.如演示样例中$("p")会得到一组P标签元素,当中"p"表示CSS中的标签选择器.$()中的 ...

  5. 利用ItextPdf、core-renderer-R8 来生成PDF

    近期因为工作上的须要,须要做一个简历产品的下载功能,而下载的形式要去为PDF,内容要求为整个简历的内容,并且格式上要求和简历的格式排版时一致的!前期调研.开发,最后測试上线.差点儿相同花了7天的时间. ...

  6. [android开发IDE]adt-bundle-windows-x86的一个bug:无法解析.rs文件--------rs_core.rsh file not found

    google的android自带的apps写的是相当牛逼的,将其导入到eclipse中方便我们学习扩展.可惜关于导入的资料太少了,尤其是4.1之后的gallery和camera合二为一了.之前导4.0 ...

  7. 取得正在运行的Activity

    在main.xml中: <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns: ...

  8. XCode常用快捷键(转)

    刚开始用Xcode是不是发现以前熟悉的开发环境的快捷键都不能用了?怎么快捷运行,停止,编辑等等.都不一样了.快速的掌握这些快捷键,能提供开发的效率. 其实快捷键在Xcode的工具栏里都标注有,只是有的 ...

  9. html系列教程--标题,水平线,注释以及段落

    HTML标题 标题,用来显示文章重要性的文字,包含了文章的主旨,类似于作文题目. 标题(Heading)是通过 <h1> - <h6> 等标签进行定义的,由大到小一次排列,h1 ...

  10. Ubuntu Android Studio 无法通过起动器开启

    问题: 1.可以通过终端开启 2.通过Android-Studio建立的Application无法启动, 提示 No JDK found. Please validate either STUDIO_ ...