- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我首先使用实体框架代码开发了一个非常简单的网络应用程序。经过几个小时的挫折,我意识到即使 localdb 是 SQL Server Express,它实际上并不意味着在使用“发布”(发布向导)时用于生产。仅供引用,我使用的是 EF 6.1.3、SQL Server 2014、VS 2013 和 IIS 7。
如果我理解正确,当您单击使用 localdb 发布时,您实际上所做的就是将 localdb 数据库复制到您的 IIS 7 服务器。我无法弄清楚为什么当我通过 VS 迁移更新我的 lodaldb 数据库时,我的生产服务器数据库没有被更新。我理解(并且现在相信)它实际上是 localdb 的两个不同实例,因此不是相同的数据。
好吧,我已经完成了 localdb,我在我的机器上创建了一个真正的 SQL Server 2014 数据库。我在谷歌上搜索了几个小时,现在不知道该怎么做。我有一些问题:
如何使用 EF 管理这个新数据库?例如,假设我想添加一个新列。首先,我将它添加到我的 localdb,进行一些测试,然后使用 Add-Migration blah 进行迁移,然后使用 Update-Database ... 然后我是否必须使用 VS 生成 SQL 脚本,然后在生产数据库服务器上手动运行它?
我知道这不太好,但我可以不使用带有 Entity Framework 的本地数据库,而是将 EF 附加到一个真正的暂存 SQL Server 数据库(一个测试数据库)并跳过所有这些 localdb 牛*** *?那么我可以使用代码优先迁移来管理它并使所有内容保持同步吗?
我应该使用 Initializer 吗?我读过关于是否将这些用于生产数据库(比如这个)的相互矛盾的报告
公共(public)类 PricedNotesInitializer:MigrateDatabaseToLatestVersion<...,...> {
令人沮丧的是,我了解这些东西的唯一方法是通过其他沮丧的人的博客文章。我不明白为什么文档如此垃圾。
感谢您的帮助,对于您的咆哮,我们深表歉意。
最佳答案
您可以使用 MigrateDatabaseToLatestVersion初始化程序,以便在部署后首次启动应用程序时自动完成对数据库的模式更改(如果可能,不会丢失数据)。
如果发生数据丢失,您将收到错误消息并且必须采取适当的措施。即使数据丢失,也可以覆盖它以继续。
正如其他答案已经指出的那样,每个环境都需要一个连接字符串,因此 LocalDB 适合开发,我什至鼓励它,因为它可以为任何新开发人员自动创建和初始化(并使用测试数据播种)需要通过从源代码构建和运行应用程序来开发或调试它。
除了加载解决方案、构建和运行代码库之外,“设置新的开发环境”体验应该尽可能流畅,手动步骤最少,最好是零。
您的部署和发布管道应该是自动的,不需要任何可能被错误执行、被遗忘或更糟的手动命令。
如果您想谨慎行事或满足某些合规性要求,手动步骤可能是对分阶段更改进行简单的是/否批准。
然而,您的暂存环境中的自动化测试应该可以缓解这种情况,并在成功时自动部署到生产环境中 - 在一个完美的世界中 ;)
针对生产手动运行 update-database 需要任何运行它的机器都可以访问生产数据库——我会说,如果您以交互方式运行它,这是不太可能或不推荐的情况。如果需要,您可以 script it作为自动部署管道的一部分,如果你想要比使用初始化器更多地控制它,这似乎最适合更简单的项目(虽然这个项目似乎是这样)。
关于c# - 首先使用生产数据库部署 Entity Framework 代码,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39513211/
我在 *.sql 文件中得到了我的数据库转储(表、函数、触发器等)。此时我正在通过 jenkins 部署它们,通过传递执行 shell 命令: sudo -u postgres psql -d my_
我正在使用网络部署 API 来部署网络包(.zip 文件,由 MSDeploy.exe 创建)以编程方式将包发布到服务器(在发布包之前我们需要做一些其他事情这就是为什么我们不使用 MSDeploy.e
我们正在使用 Web Deploy 3 的(几乎完全未记录的)“公共(public) API”来创建我们网站的 .zip 包,然后将其同步到服务器: DeploymentBaseOptions des
将 clojure 应用程序制作成可执行文件的最简单方法是什么,例如 http://rawr.rubyforge.org/ ruby 吗? (exe 和 app 文件也是) 最佳答案 使用 leini
是否可以下载 Android 源代码并针对任何设备进行编译? 我想做的是尝试 GSM 代码部分并编译操作系统并将其部署到我的摩托罗拉手机上。 谢谢! 最佳答案 是的,但这很难,因为大多数手机不共享驱动
我正在考虑用 c/c++ 编写需要在大多数个人计算机上运行的 nbody 样式模拟。本质上是一个 O(n^2) 粒子模拟器。 因为这需要相当用户友好,所以我希望有 1 个不需要用户安装任何东西的 Wi
需要了解 kubernetes 部署中 kube_deployment_status_replicas 和 kube_deployment_spec_replicas 指标的区别 最佳答案 简而言之,
我正在尝试使用分类器部署 Maven Artifact 。由于我需要源代码和 JAR(我从 GWT 使用它),我想获得 artifact-version-classifier.jar 和 artifa
我设置部署以将我的项目代码与存储我的网站的 FTP 服务器上的项目同步。 但是,每次尝试同步时,我总是必须登录。 我什至检查了记住,但它不起作用! 我正在使用最新的 PhpStorm 2017.1.4
我在 Visual Studio 2008 中开发了一个 ASP.NET 网站。现在我想在其他机器上部署它。我怎样才能做到这一点??就像我们为 Windows 应用程序制作安装包一样,我们可以为 AS
将 QT 框架添加到我的 .app 包中 我正在关注 Qt 站点上关于部署的文档。 我创建了一个名为 HTTPClient.app 的应用程序 我在 Contents 下创建了 Framework 文
这个问题不太可能对任何 future 的访客有帮助;它只与一个小的地理区域、一个特定的时间点或一个非常狭窄的情况相关,通常不适用于互联网的全局受众。如需帮助使这个问题更广泛适用,visit the h
我正在研究改变我目前创建营销网站的策略。目前,我完全用 PHP 从头开始构建网站,使用一个简单的包含系统。所有代码(以及内容)都存储在文件(而不是数据库)中,允许我使用 Subversion 进行
我有一个长期运行的服务(在 while 1 循环中)并通过 GCloud pub/sub 处理有效负载,之后它将结果写入数据库。 该服务不需要监听任何端口。 Kind=Deployment 的声明性
似乎部署已停滞不前。我该如何进一步诊断? kubectl rollout status deployment/wordpress Waiting for rollout to finish: 2 ou
我正在Dart中使用前端的Angular和后端的Shelf构建一个客户端/服务器应用程序。当我执行pub build时,它会按预期生成Dart文件的javascript,但不会替换HTML文件中的Da
我在 Azure 部署中心的下拉列表中看不到我的所有 Github 组织存储库。 Azure 很久以前就已经被授权了,下拉列表正确地显示了所有的存储库,直到上周我在 DevOps 中玩游戏时,不得不再
我认为标题几乎说明了一切...对于 Deployd 来说是全新的,所以任何关于如何最好地实现这一点的指示都值得赞赏。 最佳答案 要获取用户创建的集合中的对象(我假设您使用的是 javascript 库
我有一个试图用于CD服务器的部署脚本,但是在编写bash脚本以完成一些所需的步骤(例如运行npm和迁移命令)时遇到了问题。 我将如何从该脚本进入容器bash,运行下面的命令,然后退出以完成对更改的提取
我想在使用 kubectl 时将参数传递给 Kubernetes 部署命令应用部署文件。 示例:在我的部署 .yaml 中,我有如下参数,我想在使用 kubectl apply - f .yaml 运
我是一名优秀的程序员,十分优秀!