DataTable && SqlDataReader帮助理解小程序
// 2015/07/08
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Data;
using System.Data.SqlClient; namespace DataTapleSample
{
class Program
{
static void Main(string[] args)
{
// 通用的专门用来保存数据库中数据的类型
DataTable table = new DataTable(); // 在DataTable 中保存数据之前,必须先定义结构
DataColumn stuid =
//new DataColumn("StuId",System.Type.GetType("System.Int32"));
new DataColumn("StuId",typeof(int));//简写方式和前者等价
DataColumn stuname = new DataColumn("stuName",typeof(string));
DataColumn stuaddress = new DataColumn("stuaddress",typeof(string)); // 创建表的结构
table.Columns.Add(stuid);
table.Columns.Add(stuname);
table.Columns.Add(stuaddress); // 表的约束
// 主键约束
table.PrimaryKey = new DataColumn[]{stuid}; // 非空约束
// stuaddress.AllowDBNull = false;
// 唯一约束:stuname.Unique; // 如何在 DataTable 中保存数据
// DataRow 表示保存在 DataTable 中的一行数据
DataRow row = table.NewRow(); // 使用 NewRow 方法创建的行,结构与表是相同的(如下三种方法,建议第一种)
// row[stuid] = 1;
// row[1] = "XXXX";
// row[stuaddress] = "XXXX";
row[stuid] = 7;
row[stuname] = "XX";
row[stuaddress] = "XXX"; // 现在加入到 DataTable 中
table.Rows.Add(row); // 访问保存在 DataTable 中的数据
foreach (DataRow r in table.Rows)
{
Console.WriteLine("stuid:{0},stuName:{1},stuaddress:{2}",r[0],r[1],r[2]);
}
Console.ReadKey();
}
}
}
//////////////////////////////////////////////////////////////
// next // 2015/07/08
// DataTable && SqlDataReader
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Data;
using System.Data.SqlClient; namespace StuDataTable
{
class Program
{
static void Main(string[] args)
{
// 保存在 DataTable 中
DataTable table = new DataTable(); string connectionString = "server=.;database=BookSample;uid=sa;pwd=123456";
using (SqlConnection connection = new SqlConnection(connectionString))
{
string sql = "select ID,StuName,Phone from students";
SqlCommand cmd = new SqlCommand(sql,connection); connection.Open(); using (SqlDataReader reader = cmd.ExecuteReader())
{
// 根据查询结果的结构来创建对应的 DataTable
int columnCount = reader.FieldCount; // 查询结果的列数 // 逐列创建
for (int i = 0; i < columnCount; i++)
{
DataColumn column = new DataColumn(
reader.GetName(i),
reader.GetFieldType(i)
);
table.Columns.Add(column);
} // 逐行从数据库中读取数据
while (reader.Read())
{
DataRow row = table.NewRow(); for (int i = 0; i < columnCount; i++)
{
row[i] = reader[i];
}
table.Rows.Add(row);
}
} } // 现在数据库中的数据已经保存到内存中特殊的集合中
foreach (DataRow row in table.Rows)
{
// 将 ID 读取出来
Console.WriteLine(row["ID"]);
}
Console.ReadKey();
}
}
} /*
相关阅读:
https://msdn.microsoft.com/zh-cn/library/system.data.datatable.aspx
https://msdn.microsoft.com/zh-cn/library/system.data.sqlclient.sqldatareader.aspx */
DataTable && SqlDataReader帮助理解小程序的更多相关文章
- 微信小程序开发:学习笔记[7]——理解小程序的宿主环境
微信小程序开发:学习笔记[7]——理解小程序的宿主环境 渲染层与逻辑层 小程序的运行环境分成渲染层和逻辑层. 程序构造器
- 微信小程序开发——以简单易懂的浏览器页面栈理解小程序的页面路由
前言: 对于小程序的页面路由,如果没有一定开发经验的话,理解起来还是会有些困难的.哪怕是有一定小程序开发经验的开发者,能够完全理解掌握的恐怕也不多. 这里就以另外一种方式来详细的介绍小程序的页面栈及路 ...
- 小程序学习-理解小程序中响应式单位rpx
微信小程序的官方文档用rpx来做响应式布局单位!那什么是rpx,应该如何设置呢?今天我们就来好好了解一下. [像素]:它不是自然界的物理长度,指基本原色素及其灰度的基本编码. [物理像素]:它是显示器 ...
- DataAdapter&&DataSet 帮助理解小程序
// 2105/07/08 // DataAdapter&&DataSet using System; using System.Collections.Generic; using ...
- 微信小程序简单入门理解
简单的小程序示例结构: (一):理解小程序结构app.js,app.json,app.wxss ①app.js,app.json是小程序结构必要的部分,app.wxss可选择 ②app.js用于创建小 ...
- 教你理解微信小程序的生命周期和运行原理
转自:http://blog.csdn.net/tsr106/article/details/53052879 写微信小程序,他的生命周期不能不知道,不知道小程序就会出现各种bug而无法解决.小助君 ...
- 理解微信小程序的生命周期和运行原理
写微信小程序,他的生命周期不能不知道,不知道小程序就会出现各种bug而无法解决.小助君公众号带你学习小程序的生命周期和运行原理. 小程序由两大线程组成:负责界面的线程(view thread)和服务线 ...
- 理解微信小程序的双线程模型
有过微信小程序开发经验的朋友应该都知道"双线程模型"这个概念,本文简单梳理一下双线程模型的一些科普知识,学识浅薄,若有错误欢迎指正. 我以前就职于「小程序·云开发」团队,在对外的一 ...
- TODO:即将开发的第一个小程序
TODO:即将开发的第一个小程序 微信小程序是一种全新的连接用户与服务的方式,它可以在微信内被便捷地获取和传播,同时具有出色的使用体验.个人理解小程序是寄宿在微信平台上的一个前端框架,具有跨平台功能, ...
随机推荐
- IOS第三方数据库--FMDB 分类: ios技术 2015-03-01 09:38 57人阅读 评论(0) 收藏
iOS中原生的SQLite API在使用上相当不友好,在使用时,非常不便.于是,就出现了一系列将SQLite API进行封装的库,例如FMDB.PlausibleDatabase.sqlitepers ...
- Sublime Text 快捷键--持续更新
快捷键 功能 说明 ctrl+D 选取一个单词连续按组合键会选择页面所有相同的这个单词 ctrl+Z 撤销上一个操作 ctrl+Y 恢复上一个操作 ctrl+shift+F 底部打开搜索全 ...
- 使用MyEclipse开发第一个Web程序
MyEclipse环境配置 首先,安装一个MyEclipse,然后进行一些相关的环境配置(Window->Preferences): 比如字体.Formatter等. 也可以从Eclipse中导 ...
- 职业定位(Web前端、后台、PC端)
Web前端 Web前端开发工程师:http://baike.sogou.com/v18499271.htm WEB前端开发面试题集锦:http://wenku.baidu.com/view/47bbc ...
- div+CSS实现段落首行缩进两个字符
段落前面空两个字的距离,不要再使用空格了,用CSS实现段落首缩进两个字符.应该使用首行缩进text-indent.text-indent可以使得容器内首行缩进一定单位.比如中文段落一般每段前空两个汉字 ...
- YII 1.0 验证码
public function actions(){ return array ( ‘captcha’=> array( ‘class’=> ‘CCatpchaAction’, ‘heig ...
- Hibernate懒加载的三种解决方案
Hibernate懒加载的两种解决方案: 1.Hibernate.initialize(代理对象) 2.在*.hbm.xml映射文件中添加lazy="false"属性 3.使用op ...
- 让php Session 存入 redis 配置方法
首先要做的就是安装redis 安装方法:http://redis.io/download Installation Download, extract and compile Redis with: ...
- 【翻译】使用Visual Studio在Azure上部署Asp.Net Core Web应用
配置运行环境 Install the latest Azure SDK for Visual Studio. The SDK installs Visual Studio if you don't a ...
- Failed to register Grid Infrastructure type ora.mdns.type
安装11g的集群软件的时候,在最后运行root.sh脚本时候,没有执行成功,最后提示如下错误: [root@r2 ~]# /u01/app/11.2.0/grid_1/root.sh Performi ...