您现在的位置是: 首页 > 个人博客 > sqlserver数据库使用教程 个人博客
sqlserver数据库使用教程
2019-12-11 22:41:51
【工具】4270人已围观
简介 鉴于部分同学对于如何使用sqlserver数据库还不是很清楚,这里稍微作个简单的介绍:#sqlserver安装 sqlserver一般安装sqlserver2008-r2版本的。 sqlserver2008-r2百度网盘下载链接:https://pan.baidu.com/s/1fo26......
鉴于部分同学对于如何使用sqlserver数据库还不是很清楚,这里稍微作个简单的介绍:
#sqlserver安装
sqlserver一般安装sqlserver2008-r2版本的。
sqlserver2008-r2百度网盘下载链接:https://pan.baidu.com/s/1fo261JzvkbFbu75KI3ahBA 提取码:g9hw
sqlserver2008-r2安装参考如下:http://www.xiaoniucr.com/article/view/15.html
由于sqlserver的安装步骤比较多,安装过程中容易出现失误,导致安装失败,下面提供卸载步骤:
步骤参考:http://www.xiaoniucr.com/article/view/14.html
数据库安装完之后,在Window程序中一般会有如下选项,我们选中【SQL Server Management Studio】打开sqlserver登录界面,如下:
打开sqlserver登录界面之后,以Windows身份验证 登录系统,操作如下:
#数据库附加导入
在您购买的源码包中的【数据】文件夹中一般会有如下两个数据库文件,一个是.mdf,一个是.LDF。我们进行数据库附加导入一般就用到这两个文件。
成功登录数据库之后,选中【数据库】右键,然后选择【附加】按钮,弹出【附加数据库】选择框,如下:
弹出【附加数据库】选择框之后,点击【添加】按钮,弹出数据库选择框架,选择好您的mdf数据库文件,点击确定,操作如下:
一般第一次导入由于文件的权限问题,会出现如下报错,不要慌张,点击确定。
然后点击消息,查看具体的报错原因,一般出现这种【拒绝访问】的报错,都是没有权限操作数据库文件导致。
既然没有权限那就设置,具体设置如下:
选中.mdf文件,然后右键,选择【属性】,弹出如下窗体,按照步骤进行设置即可:
设置完.mdf的读写权限之后,.LDF文件的读写权限也是一样,必须两个都设置。
设置完之后,再重复上面的导入步骤,即可完成数据库导入,然后查看我们的数据库表结构:
Tags: sqlserver使用
上一篇: 前端学习小笔记
随机图文
关于查询或者添加中文乱码问题
如果你的项目在使用过程中:1.遇到输入中文无法查询(有记录,但是查询无结果)2.添加中文,保存之后页面显示乱码(比如号?????乱码)。 请检查如下两个配置,并作修改: 1.检查数据库链接地址,是否有如下标红配置,没有请加上,示例: jdbc.driver=com.mysql.jdbc.Driver jdbc.url=jdbc:mysql://localhost:3306/driving?useUnicode=true&characterEncoding=UTF-8 jdbc.user=root jdbc.password=root 以上配置可以在数据库配置文件中找到,比如.properties文件,有的是直接写在代码中。具体改动点在程序包中的详细配置文件中会有说明。 2.检查tomcat配置,找到apache-tomcat-7.0.70\conf\server.xml文件,如果不存在如下标红配置,请加上。注意:是8080端口的这个,添加完成之后,请重启tomcat;tomcat重启之后,该配置会被刷掉,所有要不时的检查改配置是否存在。 3.如果以上两种方法还没有解决问题, 那就可能就是数据库编码问题了。 参考如下解决方法:http://www.xiaoniucr.com/article/view/12.html 注意:一般第三种情况可以直接解决问题。 有趣的Java字符串
先上代码:public class Test3 { public static void main(String[] args) { String str = 1+1+"1"; String str_ = "1"+1+1; System.out.println("str:"+str); System.out.println("str_:"+str_); }}程序输出:str:21str_:111可以看到,如果运算在字符串的前面,那么会先执行运算,再讲运算结果与字符串拼接;如果运算在字符串的后面,那么运算将变得毫无意义。^_^大家可以去试试。据说是一道华为Java面试题
请问下面程序将会输出什么?程序如下:public class Test { class A{ private static final int m = 10; public A(){ change(); } public void change(){ System.out.println(m); } } class B extends A{ private static final int num = 20; public void change(){ System.out.println(num); } }}输出测试:public class Test2 { public static void main(String[] args) { new Test().new B(); }}结果公布,最终会输出:20,为什么?分析一下继承的初始化顺序。继承的初始化顺序一般如下:父类的静态变量-->父类的静态代码块-->子类的静态变量-->子类的静态代码快-->父类的非静态变量(父类的非静态代码块)-->父类的构造函数-->子类的非静态变量(子类的非静态代码块)-->子类的构造函数值得注意的是:父类的非静态变量(父类的非静态代码块)是同一级的,看哪个部分写在类的最前面谁就先被执行,子类的非静态变量(子类的非静态代码块)也是一样。所以这道题,实例化一个子类,首先会去执行父类的构造方法,执行构造方法中的函数change,但是由于change函数被子类重写了,所以执行的将是子类的change,所以会输出20;但是,如果我们把子类的中的private static final int num = 20;改为private int m = 20;那么结果又会输出什么呢?结果是0,因为在父类的构造方法中调用子类的change方法输出num的时候,num作为一个实例变量,这时候还没有被实例化赋值,所以取得是初始值0。大家猜一猜运算结果?
大家决定下面这段代码的运算结果是什么呢?public class Test { public static void main(String[] args) { int n = getNum(); System.out.println(n); } public static int getNum(){ int a = 10; try { a = 20; throw new RuntimeException(); } catch (Exception e) { a = 30; return a; }finally{ a = 40; } }}略微思考,大家都应该知道结果,是30,分析一下:首先,初始化变量a的值为10,继续执行,重新将a赋值为20,这时抛了一个异常,被catch捕获,这是a再次被重新赋值为30,这时候看到了return关键字,程序保存方法返回值(这个返回值将作为最后的运行结果,返回给外部调用),最后执行finally,执行完之后,再把前面运行得到的结果返回给程序调用。
点击排行
