2、ABPZero系列教程之拼多多賣家工具 更改資料庫為Mysql

来源:https://www.cnblogs.com/shensigzs/archive/2018/01/13/8278911.html

因為要部署項目到雲伺服器,不想在伺服器上裝SqlServer,所以需要把項目改為Mysql。 項目初始化 1、下載項目壓縮包,前面文章已經說到,可以加群到群文件里下載。解壓縮下載的項目源碼,使用VS2015打開項目 這裡需要還原包,選擇解決方案 右鍵(還原NuGet包),現在還原NuGet包比之前快 ...

 

  因為要部署項目到雲伺服器,不想在伺服器上裝SqlServer,所以需要把項目改為Mysql。

項目初始化

  1、下載項目壓縮包,前面文章已經說到,可以加群到群文件里下載。解壓縮下載的項目源碼,使用VS2015打開項目

 

 

這裡需要還原包,選擇解決方案---右鍵(還原NuGet包),現在還原NuGet包比之前快了好多了,這都是微軟重視中國開發者的功勞。

 

 

包還原好了之後,點擊解決方案重新生成一次。可以看到項目生成成功,接下來進入修改Mysql資料庫步驟。

註:如果你不想使用Mysql資料庫,可以跳過以下一些步驟,直接進入資料庫創建步驟。

安裝Mysql包

在此之前先安裝Mysql資料庫,電腦上安裝Mysql資料庫,確保電腦可以成功連接Mysql資料庫。

Mysql免安裝版環境配置圖文教程:http://www.jb51.net/article/83636.htm

 

然後安裝Mysql的包,EntityFramework和Web項目都需要安裝

 

上圖中已經圈出該安裝的NuGet包與安裝到哪個項目,這裡選擇6.9.10版本

Web項目

打開web.config修改連接字元串

<connectionStrings>
    <!--<add name="Default" connectionString="Server=localhost; Database=AbpZeroTemplate; Trusted_Connection=True;" providerName="System.Data.SqlClient" />-->
    <!-- Mysql連接字元串-->
    <add name="Default" connectionString="Data Source=localhost;port=3306;Initial Catalog=pdddb3.4;uid=root;password=ab12;Charset=utf8" providerName="MySql.Data.MySqlClient" />
    <add name="Abp.Redis.Cache" connectionString="localhost" />
  </connectionStrings>

 

安裝Mysql驅動

安裝Mysql的驅動,驅動版本選擇和上面安裝的包一樣的版本
驅動下載地址:https://dev.mysql.com/downloads/connector/net/

 

下載後一直下一步安裝就可以了。

EntityFramework項目

修改EntityFramework項目下的Configuration構造函數

文件路徑:D:\abp version\aspnet-zero-3.4.0\aspnet-zero-3.4.0\src\MyCompanyName.AbpZeroTemplate.EntityFramework\Migrations\Configuration.cs

public Configuration()
        {
            AutomaticMigrationsEnabled = false;
            ContextKey = "AbpZeroTemplate";
            //加入以下代碼
            SetSqlGenerator("MySql.Data.MySqlClient", new MySql.Data.Entity.MySqlMigrationSqlGenerator());//設置Sql生成器為Mysql的
        }

 

 

AbpZeroTemplateDbContext類上加一句特性

文件路徑:D:\abp version\aspnet-zero-3.4.0\aspnet-zero-3.4.0\src\MyCompanyName.AbpZeroTemplate.EntityFramework\EntityFramework\AbpZeroTemplateDbContext.cs

[DbConfigurationType(typeof(MySql.Data.Entity.MySqlEFConfiguration))]
    public class AbpZeroTemplateDbContext : AbpZeroDbContext<Tenant, Role, User>
    {

 

 

重新生成遷移文件

至此代碼就加好了,重新生成遷移文件,可以看到項目原來就存在很多遷移文件,我們不要這些文件,自己重新生成。

 

刪除完剩下Seed目錄和Configuration文件

 

 

註:先設置Web項目為啟動項目

 

打開VS的包管理控制台,併在包管理控制臺中選擇 .EntityFramework 項目作為預設項目。然後在控制臺中執行下麵命令:

Add-Migration "AbpZero_Initial"

 

看到上圖黃色提示說明創建遷移文件成功

 

 

同時Migrations目錄多了一個文件,這個就是剛剛創建的遷移文件。

現在你可以使用下麵命令來創建資料庫:

Update-Database

 

 

 

 

所有的事情都已完成,現在你可以運行你的項目並使用MySQL資料庫了。

這篇文件告訴你如何啟動項目,建議部署到IIS啟動,以後的文章中我都以IIS啟動進行操作。

 http://www.cnblogs.com/shensigzs/p/6258835.html

 

返回總目錄


您的分享是我們最大的動力!

更多相關文章
  • 在.NET中有兩個AuthorizeAttribute類, 一個定義在System.Web.Http命名空間下 #region 程式集 System.Web.Http, Version=5.2.3.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35... ...
  • 背水一戰 Windows 10 之 文件系統: 獲取文件夾的屬性, 獲取文件夾的縮略圖 ...
  • AdminController中添加引用: Index添加[Authorize]許可權要求: StartUp.cs中添加引用: StartUp.cs ConfigureServices中添加常量: 添加中間件: 此時,訪問Admin頁面,自動跳轉至Account/Login?ReturnUrl=%2F ...
  • 打斷點打不出火花,這個問題糾結了我兩天時間,查問了度娘許久,網上各種說法。我一直認為是我的環境設置問題,但就是沒辦法找到問題所在。 我想起哪天部署WEB的時候,點了一下“代碼優化”,於是還原了代碼優化,結果問題解決了。 哈哈 這樣就能打出火花了 ...
  • 1. 單一職責原則(Single Responsibility Principle) 每一個類應該專註於做一件事情。 每一個職責都是變化的一個軸線,如果一個類有一個以上的職責,這些職責就耦合在了一起。這會導致脆弱的設計。當一個職責發生變化時,可能會影響其它的職責。另外,多個職責耦合在一起,會影響復用 ...
一周排行
  • 一、課程介紹 曾經有一位不知名的講師說過這麼一句名言: 一門RPC技術不會,那麼千萬萬門RPC技術將都不會!在今天移動互聯網的時代,作為攻城師的我們,誰不想著只寫一套API就可以讓我們的Web, Android APP, IOS APP, iPad APP, Hybired APP, H5 Web共 ...
  • MVC也好,WebAPI也好,據我所知,有部分人是因為複雜的路由,而不想去學的。曾經見過一位程式猿,在他MVC程式中,一切皆路由,url中是完全拒絕"?"和“&”。對此,我也不好說什麼,搞不好是個人風格。路由雖然重要,但其實也只是實現MVC的一種手段,並非你用的路由越多,你的url完全不使用參數,你 ...
  • 基於Ubuntu安裝redis, 我找的一個很好的網站: https://www.digitalocean.com/community/tutorials/how-to-install-and-configure-redis-on-ubuntu-16-04設置redis密碼登錄, 編輯redis.c ...
  • 原文鏈接 一.Has方法: 二.With方法: ...
  • 本文的概念性內容來自深入淺出設計模式一書 項目需求 這是一個糖果機的需求圖. 它有四種狀態, 分別是圖中的四個圓圈: No Quarter: 無硬幣 Has Quater 有硬幣 Gumball Sold 糖果賣出 Out of Gumball 沒有糖果了 這個圖很像一個狀態圖. 每個圓圈就是一個狀 ...
  • 最近有個統計分佈的需求,需要按統計本周,上周,本月,上月,本季度,上季度,本年度,上年度等時間統計分佈趨勢,所以這裡就涉及到計算周,月,季度,年度等的起止時間了,下麵總結一下C#中關於根據當前時間獲取周,月,季度,年度等時間段的起止時間的方法,廢話不多說,直接貼代碼,如果你覺得有用,請多多推薦。 ...
  • 本文是一篇介紹net同步非同步的文章,是為張四火同學原創的。請張四活同學及廣大讀者指出,文章不通順的地方。後續應當還有兩篇文章敬請期待 ...
  • 在WPF里用MediaElement控制項,實現一個迴圈播放單一視頻的程式,同時可以控制視頻的播放、暫停、停止。 一種方式,使用MediaElement.MediaEnded事件,在視頻播放結束後,自動重新播放; 另一種方式,使用WPF定時器,在定時器事件里寫入視頻播放代碼。 後者優點是可以控制迴圈時 ...
  • 最近因為公司業務需要,又有機會擼winform了,這次的需求是因為公司有項目申報的這塊業務,項目申報前期需要關註政府發佈的相關動態信息,政府部門網站過多,人工需要一個一個網站去瀏覽和查閱,有時候還會遺漏掉,因此呢,我們打算用爬蟲+移動端web來做,我呢主要負責爬蟲和web Api。 爬蟲篇 爬蟲主要 ...
  • AspNetCoreApi 跨域處理 如果咱們有處理過MV5 跨域問題這個問題也不大。 (1)為什麼會出現跨域問題: 瀏覽器安全限制了前端腳本跨站點的訪問資源,所以在調用WebApi 介面時不能成功訪問資源,原因“同源策略”的存在: 同源指以下幾點相同 (1) IP地址/功能變數名稱 (2) 埠號 (3) ...