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:即将开发的第一个小程序 微信小程序是一种全新的连接用户与服务的方式,它可以在微信内被便捷地获取和传播,同时具有出色的使用体验.个人理解小程序是寄宿在微信平台上的一个前端框架,具有跨平台功能, ...
随机推荐
- Keil C 里面Lib库文件的生成与调用
源:Keil C 里面Lib库文件的生成与调用
- Java对象嵌套
1.基础篇 Java面向对象东西太深奥了,本文只是发表一点自己的见解. 首先 举个栗子!! 汽车, 我们先给汽车定义个轮胎类 有一个属性名 轮胎尺寸 /** *定义一个轮胎类 */ class Wh ...
- IOS开发-UI学习-UITextField的各种属性设置
UITextField是IOS中非常常用的一个控件,用来接收用户输入信息,完成应用和用户的交互.它的主要属性设置如下: //初始化textfield并设置位置及大小 UITextField *text ...
- ios数据存储——数据库:SQlite3以及第三方库FMDB
[reference]http://blog.csdn.net/mad1989/article/details/9322307 原生数据库:SQlite3 一.必备条件 在ios项目中使用sqlite ...
- 理解javascript:void(0);和href="#"
我们经常可以看见这样的代码: <a href="javascript:void(0);">链接</a> void的意思是空的,无效的意思,但是在js中是表示 ...
- datalog
https://en.wikipedia.org/wiki/Datalog http://www.csd.uoc.gr/~hy562/1112_spring/instr_material/WhatYo ...
- 【滚动数组】【状压dp】Gym - 100956F - Colored Path
f(i,j,S)表示到(i,j),且经由的路径上的颜色集合为S的价值的最小值,从上方和左方转移过来即可. 要注意,内存不足,需要滚动数组优化,即使用了map,还是需要. 路径输出的时候,可以再跑一遍d ...
- Yii 1.0 基础
骨架搭建 1.下载2.windows 创建PHP环境变量,找到php.exe的目录D:\wamp\bin\php\php5.3.5,右键我的电脑,属性\高级设置,path最后添加 ;D:\wamp\b ...
- Selenium2(java)定位页面元素 二
辅助工具: chrome浏览器,F12打开控制台; Firefox浏览器,F12打开控制台; 或者选中要定位的元素右键 安装firefox扩展firebug和firepath; 安装之后F12可调用f ...
- iOS 知识点
1. @dynamic.@synthesize 2. iOS NSTimer 3. iOS 之 Aggregate Target 4. iOS 属性之assign.copy.retain 5. iOS ...