zoukankan      html  css  js  c++  java
  • 在visual studio2012中如何使用localDB具体讲解

    http://www.cnblogs.com/zhangran/archive/2012/08/26/2657864.html

     说明: 经过一段时间的小捉摸终于基本掌握在vs2012中如何使用localDB了,当然包括其中令人头疼的

      connectionStrings的设置,这也算承接我之前写的一篇文章初试visual studio2012的新型数据库Loc

       alDB,现在就将一下我的理解,初学可能有错,欢迎指正^_^

           首先我是在vs2012种创建的一个mvc3项目,然后用的是EntityFramework的方式来访问数据库的,EF不太懂得也

       没多大关系,我感觉EF就是一个类库文件,里面许多便于我们访问数据库、操作数据库的一些类和方法就是了。

       关于EF大家一定清楚它的Code First模式吧,这次我是用两种方式分别来调用数据库的,第一种就是普通的Code

       First方式,先建立一个Model类,然后自动mapping一个数据库出来,第二种就是自己手动创建一个数据库,然后

       改写连接字符串connectionstrings使自己的应用能连接数据库。下面分着讲:

          第一种:

           创建一个实体类跟一个数据库上下文类

    复制代码
    public class Product
        {
            public int ProductID { get; set; }
            public string Name { get; set; }
            public string Description { get; set; }
            public decimal Price { get; set; }
            public string Category { get; set; }
        }

      class EFDbContext :DbContext
        {
            public DbSet<Product> Products {get;set;}
        }
    复制代码

    也许上面的类名大家面熟吧,呵呵,我是在做pro asp.net mvc3上面的练习时遇到的问题,就直接把我现成的代码粘过来了(无侵权之意)。

         接下来就是修改web.config下面的连接字符串了

           <add name="EFDbContext" providerName="System.Data.SqlClient"

             connectionString="Data Source=(LocalDb)v11.0;Initial Catalog=SportsStore;

             Integrated Security=SSPI;AttachDBFilename=|DataDirectory|SportsStore.mdf" />

            其中,name属性一定要跟自己的DbContext类名相一致,如果此处不一致就找不到数据库了,它俩就是匹配作

         用 。这样写之后EFDbContext类才会去跟该字符串指向下的数据库做映射。

         其中的Data Source指定数据库类型

         其中Integrated Security指的是登陆类型,此处跟写“True”作用一样,就是可以以windows 身份登录,每

         次登录你就不用输账号密码了。如果是“false”就是指的sql server方式登录就要账号密码齐全。

         其中Initial Catalog属性就是初始数据库名称,字面也知道个大概,我也不详细说了,至于他有没有深层次

         的作用我还不知道,这不是易出错点。

         其中AttachDBFilename指的是一个路径,放mdf文件的地方,上面的写法是指的该文件放在自己工程的

         App_Data文件夹下面,AttachDBFilename=c:SportsStore.mdf指的就是c盘根目录下了,所以你可以根据

         这个属性来改变访问的mdf文件。

         上面的字符串写完以后运行会自动声称一个数据库SportsStore在你的App_Data文件夹下。

                            

         上图可以看出生成一个EFDbContext数据库,开始我就是以为这是个数据库名称,但想想自己的数据库不是

       SportsStore吗,后来判断此名应该是一个连接的名词,当你改变connectionstrings下面的name属性时,

       该名字是跟着变化的。可以在这个Products表中添加几条信息,然后从程序中读出来,我的没问题很顺利

       得到了数据库(当然这个顺利也是折腾了好久之后的了)。

         第二种:

          当然还得需要上面的实体类,不许多讲,打开服务器资源管理器,右键点击“数据连接”创建新Sql Server数

       据库,服务器名填(localdb)v11.0

           

           我们创建一个新数据库名为“People”,目的是用前面的程序再去访问这个新建的数据库,熟悉一下怎样进行数据库之间的转换使用。

           在这个新数据库中创建一个表Products,里面的结构要跟前面的一个样,这样才能把证你的实体类跟它也能正确匹配。

    注意: 这里要说明的是在定义表结构的时候,想要保存表是按左上角的“更新”按钮,而不是像以前那样ctrl+s,来保存了。

           然后就是修改connectionstrings改变应用让程序访问People数据库而不再是SportsStore数据库。

        <add name="EFDbContext" providerName="System.Data.SqlClient" connectionString=

        "Data Source=(LocalDb)v11.0;Initial    Catalog=People;

         Integrated Security=SSPI;AttachDBFilename=C:Users anPeople.mdf"/>

    记得name属性该填的内容要准确,另外自己建的数据库默认在用户文件夹下面。

           完成这些操作就能顺利的改变数据库的引用了^_^

          再讲一个我范二的地方,建表的时候表的列名要跟你的实体类的属性名一一对应的,而我写的顺序错了,结果在执行的时

          候vs总会自动新建一个数据库实例,后来总算明白了,所以映射这东西就是一一对应一处也不能出错的,望谨记

  • 相关阅读:
    go语言圣经第8章Goroutines 和 Channels
    VSCODE远程开发 golang环境配置
    golang排序简述
    go语言圣经第七章笔记-接口
    Java并发编程小记
    [Effective Modern C++] Item 7. Distinguish between () and {} when creating objects
    [Effective Modern C++] Item 6. Use the explicitly typed initializer idiom when auto deduces undesired types
    [Effective Modern C++] Item 5. Prefer auto to explicit type declarations
    [Effective Modern C++] Item 4. Know how to view deduced types
    [Effective Modern C++] Item 3. Understand decltype
  • 原文地址:https://www.cnblogs.com/zkwarrior/p/4824346.html
Copyright © 2011-2022 走看看