中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

SQL中如何使用DataContext連接字符串

發布時間:2021-08-02 16:46:55 來源:億速云 閱讀:143 作者:Leah 欄目:編程語言

SQL中如何使用DataContext連接字符串,相信很多沒有經驗的人對此束手無策,為此本文總結了問題出現的原因和解決方法,通過這篇文章希望你能解決這個問題。

LINQ to SQL有很多值得學習的地方,這里我們主要介紹LINQ to SQL使用DataContext連接字符串,包括介紹創建和刪除數據庫等方面。

DataContext作為LINQ to SQL框架的主入口點,為我們提供了一些方法和屬性,本文用幾個例子說明DataContext幾個典型的應用。
◆CreateDatabase方法用于在服務器上創建數據庫。
◆DeleteDatabase方法用于刪除由DataContext連接字符串標識的數據庫。

數據庫的名稱有以下方法來定義:
◆如果數據庫在連接字符串中標識,則使用該連接字符串的名稱。
◆如果存在DatabaseAttribute屬性(Attribute),則將其Name屬性(Property)用作數據庫的名稱。
◆如果連接字符串中沒有數據庫標記,并且使用強類型的DataContext,則會檢查與DataContext繼承類名稱相同的數據庫。如果使用弱類型的DataContext,則會引發異常。
◆如果已通過使用文件名創建了DataContext,則會創建與該文件名相對應的數據庫。

我們首先用實體類描述關系數據庫表和列的結構的屬性。再調用DataContext的CreateDatabase方法,LINQ to SQL會用我們的定義的實體類結構來構造一個新的數據庫實例。還可以通過使用 .mdf 文件或只使用目錄名(取決于連接字符串),將 CreateDatabase與SQL Server一起使用。LINQ to SQL使用DataContext連接字符串來定義要創建的數據庫和作為數據庫創建位置的服務器。

說了這么多,用一段實例說明一下吧!

首先,我們新建一個NewCreateDB類用于創建一個名為NewCreateDB.mdf的新數據庫,該數據庫有一個Person表,有三個字段,分別為PersonID、PersonName、Age。

public class NewCreateDB : DataContext  {   public Table<Person> Persons;  public NewCreateDB(string connection)  :  base(connection)  {  }  public NewCreateDB(System.Data.IDbConnection connection)  :  base(connection)  {  }  }   [Table(Name = "Person")]  public partial class Person : INotifyPropertyChanged  {   private int _PersonID;  private string _PersonName;  private System.Nullable<int> _Age;   public Person() { }   [Column(Storage = "_PersonID", DbType = "INT",  IsPrimaryKey = true)]  public int PersonID  {  get { return this._PersonID; }  set  {  if ((this._PersonID != value))  {  this.OnPropertyChanged("PersonID");  this._PersonID = value;  this.OnPropertyChanged("PersonID");  }  }  }   [Column(Storage = "_PersonName", DbType = "NVarChar(30)")]  public string PersonName  {  get { return this._PersonName; }  set  {  if ((this._PersonName != value))  {  this.OnPropertyChanged("PersonName");  this._PersonName = value;  this.OnPropertyChanged("PersonName");  }  }  }   [Column(Storage = "_Age", DbType = "INT")]  public System.Nullable<int> Age  {  get { return this._Age; }  set  {  if ((this._Age != value))  {  this.OnPropertyChanged("Age");  this._Age = value;  this.OnPropertyChanged("Age");  }  }  }   public event PropertyChangedEventHandler PropertyChanged;  protected virtual void OnPropertyChanged(string PropertyName)  {  if ((this.PropertyChanged != null))  {  this.PropertyChanged(this,  new PropertyChangedEventArgs(PropertyName));  }  }  }

接下來的一段代碼先創建一個數據庫,在調用CreateDatabase后,新的數據庫就會存在并且會接受一般的查詢和命令。接著插入一條記錄并且查詢。***刪除這個數據庫。

//新建一個臨時文件夾來存放新建的數據庫  string userTempFolder = Environment.GetEnvironmentVariable  ("SystemDrive") + @"\YJingLee";   Directory.CreateDirectory(userTempFolder);   //新建數據庫NewCreateDB  string userMDF = System.IO.Path.Combine(userTempFolder,  @"NewCreateDB.mdf");  string connStr = String.Format(@"Data Source=.\SQLEXPRESS;  AttachDbFilename={0};Integrated Security=True;  Connect Timeout=30;User Instance=True;   Integrated Security = SSPI;", userMDF);  NewCreateDB newnewDB = new NewCreateDB(connStr);  newDB.CreateDatabase();   //插入數據并查詢  var newnewRow = new Person  {  PersonID = 1,  PersonName = "YJingLee",  Age = 22 };

看完上述內容,你們掌握SQL中如何使用DataContext連接字符串的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

新化县| 福安市| 如东县| 嘉荫县| 集安市| 平乡县| 岑巩县| 黎川县| 乌拉特中旗| 厦门市| 鸡泽县| 定陶县| 塘沽区| 靖西县| 临泽县| 乌拉特中旗| 连平县| 甘谷县| 昆山市| 清流县| 泗水县| 台前县| 余江县| 云和县| 集安市| 长垣县| 大安市| 镇康县| 平阴县| 二手房| 泽普县| 玉林市| 天长市| 昌宁县| 崇仁县| 孟村| 莆田市| 略阳县| 舒城县| 玉树县| 闵行区|