前言:

此前接触过一段时间关于SqlServer的信息系统运维项目。

SqlServer最令人印象就是其 ManagementStudio 数据库管理查询界面。

最近有空,弄点事情来折腾一下。安装SqlServerExpress,这个版本你可以免费用于一些小项目。(只是一时手痒想弄一下,估计后面也派不上用场,感觉微软的技术 关注和使用的人也不少)

安装测试也费了一些功夫,网上这方面的资料也很多,只是很少涉及完整的代码连接,在此记录下来。

先说结果,这个测试环境下测试通过

WindowsServer2008R2x64 + SQLEXPR_x64_2008_CHS.exe +  SQLManagementStudio_x86_CHS.exe

(文章末段有安装包链接)

SqlServer2008资源占用较低,但毕境是版本太旧。随后又在这个测试(虚拟)环境下 安装通过。

win10_x64 + sqlserver2017express + ssms 安装成功。

这个只需官网下载个 SQLServerXXX-SSEI-Expr 安装器,直接双击安装,等待结束后,再按提示下载SSMS安装。

(另外:2008Express 免费且没期限不需注册,近乎无条件免费,且资源占用率低,WinXP打上各种补丁后也可安装32b版,可作为单机db/web vm镜像;后面高版本的SqlExpress 使用期限过后需注册才能用,是有条件地免费,且需要安装 framework 4.6 或更高的版本 。 )

【安装进行】

1, Windows环境可以是  win7_64b 或 winServer2008x64,虚拟机环境也行。

2,安装 net framework 3.5 ( 高版本数据库  需要更高版 framework )

3,安装 SQLEXPR_x64_CHS.exe ,都用默认项。模式用 windows 模式,用户帐号是 当前帐号,所有角色权限 都用这个。

4,安装 SQLManagementStudio

5,打开   SQLServer 配置管理  器,

     SqlServer 协议项,开启 TCP 和 Named 选项,

     SqlServer 服务项,重启 Sql Server。( Aent 和 Browser  可以不启动 )

6,打开 SQLManagementStudio (SMSS,连接查询界面) 

   出现 数据库 连接对话框。

   在 服务器名称 写入:(如果没有出现 服务名 的话)

   "你机器名\SQLEXPRESS"

   或   .\SQLEXPRESS   或  127.0.0.1\SQLEXPRESS

 ( 这个  SQLEXPRESS 就是安装 数据库时  默认的 实列名,在 安装时 可改。)

7,使用  Windows认证  方式,登入  Management Studio。

在这一步,必需使用   Management Studio  能成功登入  ,否则,你要检测前面什么地方有问题,必要时  用 gho 或 恢复 vmx 还原一个较纯净系统后 ,按上述步骤重新安装。

接下来,使用  编程代码 联接

Express 版本其中一个坑  就是,开放端口不是 1433  。。。

后面会提到怎么 找到 Express 的开放端口。

【连接过程】

1,前面已经讲了,在 window 授权模式下  登入 Management Studio 。

     (其实 我是 经历了很多麻烦问题后,才能登进去的,前面 的文字  只是 看起来  简单而以。。。)

    现在 Management Studio 界面的 左边是一个  树型控件 。

2,展开  树型控件,找到 下面  的 “数据库节”点,右击,新建一个数据库 ,名为  mydb  ( 或其它你期待的 )

      新建一个 查询Sql 页面。键入如下 代码,并执行 ,为 新库 授权 连接用户和 操作权限 。(相关参数自行修改)

--------------------------------------------------------

CREATE login    mydb_account  WITH password = '123456', default_database= mydb

USE  mydb

CREATE USER mydb_user FOR login mydb_account WITH default_schema = dbo 

USE mydb
EXEC sp_addrolemember 'db_owner', 'mydb_user'

--------------------------------------------------------

3,右键点击:树型控件  第一个 节点 (就是那个写着类似  {pc_machine_name}\SQLEXPRESS 的节点 )

      选“属性” ,再选“安全性”,接着,在窗口右边区域,找到 登录模式,把登录模式设置为 混合模式。

4,关闭  Management Studio , 重新打开。

      使用 Sql Server 用户模式 登录,用户名是   mydb_user ,密码就是 上面设置那个。

5,确保能用   mydb_user 连接进去。因为,用编程代码连接 使用的就是 这个  mydb_user 帐号。

6,重启 SQL Server。或者 重启一下 系统。

所有东西都好了,可以用代码进行连接了。

我一开始连接时,联不上,有错误提示。找了很方法。

最后  netstat -a  发现,系统根本没有开启  1433 端口 。。。

既然 SMSS 能连上,那它应该是有开端口的,它开了什么端口 ,怎么找 ?

回想起 Linux 下的   ps  grep  操作,那么 win 下也应该有类似命令才对。

OK,找一下,,,  搜一下就找到。

还是 netstat ,打开 终端 控制台 ( cmd,  console ) ,键入 这条 指令。

   netstat -ano | findstr /i "2568"

这里的 2568 是 Sql Server 进程 ID,通过  "配置管理" -> "SQL 服务" -> 属性列表, 可以查看  数据库 进程ID 。

这时,我机器找到的端口是   49162  。

( 估计是 MS 以  SQLExpress 作为实例名,bind 一个端口,再新建一个实例 ,端口 就变成另一个 )

(后来补充:也可以在 Sql 管理器那里把TCP属性网卡端口 全部改为 1433 )

7,在用代码连接前,如有必要或遇到其它问题,最好还是关闭一下 windows 防火墙。

C#连接代码 

//String constr = "server={机器IP},49826;database=myoa;User ID=mydb_user;Password=123456;";
            string constr = @"server={机器IP},49162\SQLEXPRESS;uid=mydb_user;pwd=123456;database=mydb_user";//复制
            SqlConnection con = new SqlConnection();
            con.ConnectionString = constr;
            con.Open();

Java连接

String url = "jdbc:sqlserver://IP:49162;DatabaseName=mydb_user";		
	String usr = "mydb_user";
	String pwd = "123456";
	String drv = "com.microsoft.sqlserver.jdbc.SQLServerDriver";
	Class.forName(drv);
	DriverManager.getConnection(url, usr, pwd);

SqlServerExpress2008 and  Management Studio  donwload