CUBRID学习笔记 16 元数据支持
简化了很多 ,在sqlserver需要用语句实现的功能
接口如下
public DataTable GetDatabases( string [] filters) public DataTable GetTables( string [] filters) public DataTable GetViews( string [] filters) public DataTable GetColumns( string [] filters) public DataTable GetIndexes( string [] filters) public DataTable GetIndexColumns( string [] filters) public DataTable GetExportedKeys( string [] filters) public DataTable GetCrossReferenceKeys( string [] filters) public DataTable GetForeignKeys( string [] filters) public DataTable GetUsers( string [] filters) public DataTable GetProcedures( string [] filters) public static DataTable GetDataTypes() public static DataTable GetReservedWords() public static String[] GetNumericFunctions() public static String[] GetStringFunctions() public DataTable GetSchema( string collection, string [] filters)<br><br>获取数据库 |
CUBRIDSchemaProvider schema = new CUBRIDSchemaProvider(conn); DataTable dt = schema.GetTables( new string [] { "%" }); Debug.Assert(dt.Columns.Count == 3); Debug.Assert(dt.Rows.Count == 10); Debug.Assert(dt.Rows[0][0].ToString() == "demodb" ); Debug.Assert(dt.Rows[0][1].ToString() == "demodb" ); Debug.Assert(dt.Rows[0][2].ToString() == "stadium" );<br><br>获取表的外键 |
CUBRIDSchemaProvider schema = new CUBRIDSchemaProvider(conn); DataTable dt = schema.GetForeignKeys( new string [] { "game" }); Debug.Assert(dt.Columns.Count == 9); Debug.Assert(dt.Rows.Count == 2); Debug.Assert(dt.Rows[0][0].ToString() == "athlete" ); Debug.Assert(dt.Rows[0][1].ToString() == "code" ); Debug.Assert(dt.Rows[0][2].ToString() == "game" ); Debug.Assert(dt.Rows[0][3].ToString() == "athlete_code" ); Debug.Assert(dt.Rows[0][4].ToString() == "1" ); Debug.Assert(dt.Rows[0][5].ToString() == "1" ); Debug.Assert(dt.Rows[0][6].ToString() == "1" ); Debug.Assert(dt.Rows[0][7].ToString() == "fk_game_athlete_code" ); Debug.Assert(dt.Rows[0][8].ToString() == "pk_athlete_code" );<br><br><br>获取索引<br><br> |
CUBRIDSchemaProvider schema = new CUBRIDSchemaProvider(conn); DataTable dt = schema.GetIndexes( new string [] { "game" }); Debug.Assert(dt.Columns.Count == 9); Debug.Assert(dt.Rows.Count == 5); Debug.Assert(dt.Rows[3][2].ToString() == "pk_game_host_year_event_code_athlete_code" ); //verify index name Debug.Assert(dt.Rows[3][4].ToString() == "True" ); //Is it a primary key?<br><br>完整例子 |
using CUBRID.Data.CUBRIDClient; using System.Diagnostics; using System.Data; namespace MetadataExample { class Program { static void Main( string [] args) { CUBRIDConnectionStringBuilder sb = new CUBRIDConnectionStringBuilder( "localhost" , "demodb" , "public" , "" , "33000" ); using (CUBRIDConnection conn = new CUBRIDConnection(sb.GetConnectionString())) { conn.Open(); CUBRIDSchemaProvider schema = new CUBRIDSchemaProvider(conn); //get tables example using (DataTable dt = schema.GetTables( new string [] { "%" })) { Debug.Assert(dt.Columns.Count == 3); Debug.Assert(dt.Rows.Count == 10); Debug.Assert(dt.Rows[0][0].ToString() == "demodb" ); Debug.Assert(dt.Rows[0][1].ToString() == "demodb" ); Debug.Assert(dt.Rows[0][2].ToString() == "stadium" ); } //get columns example using (DataTable dt = schema.GetColumns( new string [] { "game" })) { Debug.Assert(dt.Columns.Count == 11); Debug.Assert(dt.Rows.Count == 7); Debug.Assert(dt.Rows[0][3].ToString() == "host_year" ); Debug.Assert(dt.Rows[1][3].ToString() == "event_code" ); } //get users example using (DataTable dt = schema.GetUsers( null )) { Debug.Assert(dt.Columns.Count == 1); Debug.Assert(dt.Rows.Count >= 2); Debug.Assert(dt.Rows[0][0].ToString().ToUpper() == "DBA" ); Debug.Assert(dt.Rows[1][0].ToString().ToUpper() == "PUBLIC" ); } //get views example using (DataTable dt = schema.GetViews( null )) { Debug.Assert(dt.Columns.Count == 3); Debug.Assert(dt.Rows.Count == 0); } //get foreign keys example using (DataTable dt = schema.GetForeignKeys( new string [] { "game" })) { Debug.Assert(dt.Columns.Count == 9); Debug.Assert(dt.Rows.Count == 2); Debug.Assert(dt.Rows[0][0].ToString() == "athlete" ); Debug.Assert(dt.Rows[0][1].ToString() == "code" ); Debug.Assert(dt.Rows[0][2].ToString() == "game" ); Debug.Assert(dt.Rows[0][3].ToString() == "athlete_code" ); Debug.Assert(dt.Rows[0][4].ToString() == "1" ); Debug.Assert(dt.Rows[0][5].ToString() == "1" ); Debug.Assert(dt.Rows[0][6].ToString() == "1" ); Debug.Assert(dt.Rows[0][7].ToString() == "fk_game_athlete_code" ); Debug.Assert(dt.Rows[0][8].ToString() == "pk_athlete_code" ); Debug.Assert(dt.Rows[1][0].ToString() == "event" ); Debug.Assert(dt.Rows[1][1].ToString() == "code" ); Debug.Assert(dt.Rows[1][2].ToString() == "game" ); Debug.Assert(dt.Rows[1][3].ToString() == "event_code" ); Debug.Assert(dt.Rows[1][4].ToString() == "1" ); Debug.Assert(dt.Rows[1][5].ToString() == "1" ); Debug.Assert(dt.Rows[1][6].ToString() == "1" ); Debug.Assert(dt.Rows[1][7].ToString() == "fk_game_event_code" ); Debug.Assert(dt.Rows[1][8].ToString() == "pk_event_code" ); } //get indexes example using (DataTable dt = schema.GetIndexes( new string [] { "game" })) { Debug.Assert(dt.Columns.Count == 9); Debug.Assert(dt.Rows.Count == 5); Debug.Assert(dt.Rows[3][2].ToString() == "pk_game_host_year_event_code_athlete_code" ); //Index name Debug.Assert(dt.Rows[3][4].ToString() == "True" ); //Is PK? } conn.Close(); } } } } |
欢迎转载 ,转载时请保留作者信息。本文版权归本人所有,如有任何问题,请与我联系wang2650@sohu.com 。 过错
adonet的api http: //www.cubrid.org/manual/api/ado.net/8.4.1/Index.html<br><br> |
<br><br><br><br> |
<br><br><br><br><br><br><br><br> |
作者:过错
出处:http://www.cnblogs.com/wang2650/
关于作者:net开发做的久而已。十余年时光虚度!
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接。如有问题,可以邮件:wang2650@163.com
联系我,非常感谢。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· winform 绘制太阳,地球,月球 运作规律
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)