zoukankan      html  css  js  c++  java
  • 解决 Linq To SQL 中 DataContext 没有 CreateTable 方法的郁闷

    用过Linq To SQL的朋友都清楚,DataContext 有 CreateDatabase() 这个方法,但是却没有CreateTable(),有些情况下,还是需要CreateTable()的,比如说在虚拟主机上,一般都是没有建立数据库的权限。代码比较简单,看一下就明白了。

    Code
    namespace ALinq.Mapping
    {
        
    class CreateTableDemo
        {
            [Table(Name 
    = "User")]
            
    class User
            {
                [Column]
                
    public int ID;

                [Column]
                
    public string Name;

            }

            
    static void Main()
            {
                var constr 
    = @"Data Source=NOTEBOOK\SQLEXPRESS;Initial Catalog=DemoDataContext;Integrated Security=True";
                var context 
    = new DataContext(constr) { Log = Console.Out };
                var metaTable 
    = context.Mapping.GetTable(typeof(User));
                Debug.Assert(metaTable 
    != null);

                var typeName 
    = "System.Data.Linq.SqlClient.SqlBuilder";
                var type 
    = typeof(DataContext).Assembly.GetType(typeName);
                var bf 
    = BindingFlags.Static | BindingFlags.NonPublic | BindingFlags.InvokeMethod;
                var sql 
    = type.InvokeMember("GetCreateTableCommand", bf, nullnullnew[] { metaTable });
                Console.WriteLine(sql);
                
    //Excute SQL Command
            }
        }
    }
  • 相关阅读:
    HDU 2201 熊猫阿波问题==金刚坐飞机问题
    HDU 2100 (模拟进制加法)
    HDU 2151 Worm
    qsort快速排序
    HDU 1007 (最近点对+qsort对结构体的排序!!!)
    HDU 1348 wall (简单凸包)
    HDU 1392 Surround the Trees(凸包模板)
    HDU 1431素数回文
    HDU 2108 Shape of HDU(判断拐点)
    HDU 2857 Mirror and Light(镜面反射模板)
  • 原文地址:https://www.cnblogs.com/ansiboy/p/1386088.html
Copyright © 2011-2022 走看看