代码语言
.
CSharp
.
JS
Java
Asp.Net
C
MSSQL
PHP
Css
PLSQL
Python
Shell
EBS
ASP
Perl
ObjC
VB.Net
VBS
MYSQL
GO
Delphi
AS
DB2
Domino
Rails
ActionScript
Scala
代码分类
文件
系统
字符串
数据库
网络相关
图形/GUI
多媒体
算法
游戏
Jquery
Extjs
Android
HTML5
菜单
网页交互
WinForm
控件
企业应用
安全与加密
脚本/批处理
开放平台
其它
【
CSharp
】
访问Access表结构查询表列信息
作者:
Dezai.CN
/ 发布于
2013/2/23
/
827
access不像sqlserver,oracle有提供直接的系统表,可以查询相关表的列信息,因此直接用sql无法查找到相关信息,需要通过程序实现
public static DataSet GetOleDbColumns(DBlink dbLink, string tableName) { DBHelperOleDb.connectionString = dbLink.linkConnStr; DataTable dtKey = DBHelperOleDb.GetPrimaryInfo(tableName);//获取主键信息 DataTable result = DBHelperOleDb.GetColumnInfo(tableName);//获取列信息 DataTable dt = new DataTable(); dt.Columns.Add(new DataColumn("tableName", typeof(string))); dt.Columns.Add(new DataColumn("tableDescription", typeof(string))); dt.Columns.Add(new DataColumn("colOrder", typeof(string))); dt.Columns.Add(new DataColumn("columnName", typeof(string))); dt.Columns.Add(new DataColumn("IsIdentity", typeof(string))); dt.Columns.Add(new DataColumn("IsPrimaryKey", typeof(string))); dt.Columns.Add(new DataColumn("TypeName", typeof(string))); dt.Columns.Add(new DataColumn("Length", typeof(string))); dt.Columns.Add(new DataColumn("Precision", typeof(string))); dt.Columns.Add(new DataColumn("Scale", typeof(string))); dt.Columns.Add(new DataColumn("Nullable", typeof(string))); dt.Columns.Add(new DataColumn("DefaultVal", typeof(string))); dt.Columns.Add(new DataColumn("Description", typeof(string))); foreach (DataRow row in result.Rows) { DataRow r = dt.NewRow(); r["tableName"] = row["TABLE_NAME"].ToString(); r["tableDescription"] = row["TABLE_CATALOG"].ToString(); r["colOrder"] = row["ORDINAL_POSITION"].ToString();// r["columnName"] = row["COLUMN_NAME"].ToString(); r["IsIdentity"] = false;//还未找到对应项 r["IsPrimaryKey"] = dtKey.Select(string.Format("COLUMN_NAME='{0}'", row["COLUMN_NAME"].ToString())).Length > 0 ? true : false;//是否是主键 r["TypeName"] = row["DATA_TYPE"].ToString(); r["Length"] = row["CHARACTER_MAXIMUM_LENGTH"].ToString(); r["Precision"] = row["NUMERIC_PRECISION"].ToString(); r["Scale"] = row["NUMERIC_SCALE"].ToString(); r["Nullable"] = bool.Parse(row["IS_NULLABLE"].ToString()); r["DefaultVal"] = row["COLUMN_DEFAULT"].ToString(); r["Description"] = row["DESCRIPTION"].ToString(); dt.Rows.Add(r); } DataSet ds = new DataSet(); ds.Tables.Add(dt); return ds; } /// <summary> /// 获取Access表列信息 /// </summary> /// <returns></returns> public static DataTable GetColumnInfo(string tableName) { //connectionString = @"Provider=Microsoft.Jet.OLEDB.4.0;Data Source=E:\Project\OrgCertificate\OrgCertificate\bin\Debug\OrgCertificateDB.mdb;User ID=;Password=;"; using (OleDbConnection connection = new OleDbConnection(connectionString)) { connection.Open(); DataTable dt = connection.GetOleDbSchemaTable(OleDbSchemaGuid.Columns, new object[] { null, null }); DataView view = new DataView(); view.Table = dt; view.RowFilter = string.Format("table_name='{0}'",tableName); return view.ToTable(); } } /// <summary> /// 获取Access表主键信息 /// </summary> /// <param name="tableName"></param> /// <returns></returns> public static DataTable GetPrimaryInfo(string tableName) { using (OleDbConnection connection = new OleDbConnection(connectionString)) { connection.Open(); DataTable dt = connection.GetOleDbSchemaTable(OleDbSchemaGuid.Primary_Keys, new object[] { null, null }); DataView view = new DataView(); view.Table = dt; view.RowFilter = string.Format("table_name='{0}'", tableName); return view.ToTable(); } }
试试其它关键字
Access表结构
同语言下
.
文件IO 操作类库
.
Check图片类型[JPEG(.jpg 、.jpeg),TIF,GIF,BMP,PNG,P
.
机器名和IP取得(IPV4 IPV6)
.
Tiff转换Bitmap
.
linqHelper
.
MadieHelper.cs
.
RegHelper.cs
.
如果关闭一个窗体后激活另一个窗体的事件或方法
.
创建日志通用类
.
串口辅助开发类
可能有用的
.
C#实现的html内容截取
.
List 切割成几份 工具类
.
SQL查询 多列合并成一行用逗号隔开
.
一行一行读取txt的内容
.
C#动态修改文件夹名称(FSO实现,不移动文件)
.
c# 移动文件或文件夹
.
c#图片添加水印
.
Java PDF转换成图片并输出给前台展示
.
网站后台修改图片尺寸代码
.
处理大图片在缩略图时的展示
Dezai.CN
贡献的其它代码
(
4037
)
.
多线程Socket服务器模块
.
生成随机密码
.
清除浮动样式
.
弹出窗口居中
.
抓取url的函数
.
使用base HTTP验证
.
div模拟iframe嵌入效果
.
通过header转向的方法
.
Session操作类
.
执行sqlite输入插入操作后获得自动编号的ID
Copyright © 2004 - 2024 dezai.cn. All Rights Reserved
站长博客
粤ICP备13059550号-3