本文转自:http://www.cnblogs.com/zhangran/archive/2012/08/26/2657864.html

初试visual studio2012的新型数据库LocalDB

 

今天在vs2012里面打开以前的mvc3项目,结果弹出警告说在vs2012中数据库不建议使用sql server express而是改成用LocalDB。于是就对LocalDB做了一下了解。

LocalDB是轻型的sql server express,基本能完成后者的作用但是做了大量的简化。我装vs2012的时候是完整安装的,所有的插件都勾选了(提个建议如果是.net开发人员还是把C盘预留大一点的空间吧,我的是70G)。在这种情况下LocalDB已经存在你的电脑上了。

注意一点如果你的电脑跟我一样是64位的那么该工具是安装到64位的Program Files文件夹下面的而不是Program Files(X86)。找到这个目录C:\Program Files\Microsoft SQL Server\110\Tools\Binn。里面有一个SqlLocalDB.exe文件这就是命令行工具了。

打开cmd。定位到该目录:输入sqllocaldb.exe /?,出现下面的样子

其实你通过上下滚动阅读就会知道概述数据库的基本用法。

常用的方法:

任何操作之前都要加sqllocaldb关键字;

sqllocaldb create mybd 创建一个数据库名字为“mydb”。句尾不用加“;”。

sqllocaldb start mydb 启用该数据库实例

sqllocaldb stop mydb 停止该实例

sqllocaldb delete mydb 删除

sqllocaldb info mydb 查看数据库信息

sqllocaldb versions 查看版本

另外如果在visual studio2012中自己不去指定要用的字符串那么将默认使用LocalDB数据库。可以创建以一个普通的asp mvc3项目。选择internet项目,该项目人默认情况下就会有一个小的数据库来存储用户账号信息。执行代码后,打开web.config.

<connectionStrings>     <add name="DefaultConnection" providerName="System.Data.SqlClient" connectionString="Data Source=(LocalDb)\v11.0;Initial Catalog=aspnet-abc-20120821160659;Integrated Security=SSPI;AttachDBFilename=|DataDirectory|\aspnet-abc-20120821160659.mdf" />   </connectionStrings>

从connectionString后面的连接字符串就能看出用的是LocalDB数据库。

说明: 经过一段时间的小捉摸终于基本掌握在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\ran\People.mdf"/>

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

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

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

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

[转]初试visual studio2012的新型数据库LocalDB 及 在visual studio2012中如何使用localDB具体讲解的更多相关文章

  1. 初试visual studio2012的新型数据库LocalDB

    http://www.cnblogs.com/zhangran/archive/2012/08/21/2649200.html 今天在vs2012里面打开以前的mvc3项目,结果弹出警告说在vs201 ...

  2. 在visual studio2012中如何使用localDB具体讲解

    http://www.cnblogs.com/zhangran/archive/2012/08/26/2657864.html 说明: 经过一段时间的小捉摸终于基本掌握在vs2012中如何使用loca ...

  3. Visual Studio下SQLite数据库开发环境设置

    由于我们介绍的内容都是基于微软的Visual Studio下开发的Win32平台,所以下边我们介绍Visual Studio下SQLite数据库开发环境设置.具体而言我们有两种方式可以在Visual ...

  4. Visual Studio 单元测试之五---数据库测试

    原文:Visual Studio 单元测试之五---数据库测试 数据库的单元测试主要是测试数据库中的数据是否符合特定的条件,Visual Studio 2010支持下面几种数据的单元测试类型(Visu ...

  5. 学习时用的软件最新 开发环境为Visual Studio 2010,数据库为SQLServer2005,使用.net 4.0开发。 超市管理系统

    一.源码特点 1.采用典型的三层架构进行开发.模板分离,支持生成静态 伪静态..购物车.登陆验证.div+css.js等技术二.功能介绍 1.本源码是一个超市在线购物商城源码,该网上商城是给超市便利店 ...

  6. 传统数据库没落,OLTP新型数据库发展火热

    參考资料: (1) <OLTP Through the Looking Glass, and What We Found There> (2) <The End of an Arch ...

  7. 效率最高的Excel数据导入---(c#调用SSIS Package将数据库数据导入到Excel文件中【附源代码下载】) 转

    效率最高的Excel数据导入---(c#调用SSIS Package将数据库数据导入到Excel文件中[附源代码下载])    本文目录: (一)背景 (二)数据库数据导入到Excel的方法比较   ...

  8. 数据库的应用——直接从内存中读取osg节点 (转)

    数据库的应用——直接从内存中读取osg节点 目的:要从数据库中读取节点数据到osg. 一开始的方法是这样的,每当我要添加一个数据库中的节点数据时,首先把它读取到内存中,然后写入一个文件,最后再次从文件 ...

  9. 数据库开发——参照完整性——在外键中使用Delete on cascade选项

    原文:数据库开发--参照完整性--在外键中使用Delete on cascade选项 原文: http://www.mssqltips.com/sqlservertip/2743/using-dele ...

随机推荐

  1. EXT入门学习

    今天,对EXT做了一下初步的了解,了解了一些基本用的函数.窗体对象.表单.文本域.按钮,一些基本的函数我列了出来,写了个登陆的demo,是根据别人的例子模仿出来的,见谅哈. 基本函数 Ext.onRe ...

  2. Hibernate检索策略与检索方式

    hibernate的Session在加载Java对象时,一般都会把鱼这个对象相关联的其他Java对象也都加载到缓存中,以方便程序的调用.但很多情况下,我们不需要加载太多无用的对象到缓存中,一来会占用大 ...

  3. POJ - 2478

    Farey Sequence Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 12802   Accepted: 4998 D ...

  4. 爬虫 requests模块高级用法

    一 介绍 #介绍:使用requests可以模拟浏览器的请求,比起之前用到的urllib,requests模块的api更加便捷(本质就是封装了urllib3) #注意:requests库发送请求将网页内 ...

  5. node-java模块

    node-java模块 node-java使得开发人员,可以调用java优秀的jar包资源.有些方法逻辑,可能node不容易实现,但是java就可以很方便去做.这个时候,就可以使用node-java这 ...

  6. js判断网络连接情况:navigator.onLine

    <body> <h1 id="text">websong</h1> </body> <script> var text= ...

  7. slice切割数组arr=[[0,1],[2,3]]

    for (var i = 0; i < 10; i++) { arr.push(i) } function arrSlice(arr, num) { var arr1 = []; for (va ...

  8. LoadRunner中的C Vuser函数

    LoadRunner中的C Vuser函数     事务函数: lr_end_sub_transaction 标记子事务的结束以便进行性能分析. lr_end_transaction 标记事务的结束. ...

  9. python+django+vue搭建前后端分离项目

    以前一直是做基于PHP或JAVA的前后端分离开发,最近跟着python风搭建了一个基于django的前后端分享项目 准备工作:IDE,[JetBrains PyCharm2018][webpack 3 ...

  10. apache 占用内存总量与每个apache进程的平均内存占用量计算

    方法1: ps aux | grep httpd | grep -v pts | awk '{ tot += $6; procs += 1; print $2,$6,$11 } END { print ...