对于hibernate链接SQL Server2008出现这种原因及我本人的解决办法
<property name="connection.driver_class">com.microsoft.sqlserver.jdbc.SQLServerDriver</property>
<property name="connection.url">jdbc:sqlserver://localhost:1433;databaseName=spring</property>
<property name="connection.username">sa</property>
<property name="connection.password">gaoweigang</property>
需要在项目中引入sqljdbc4.jar
出现这种原因:1.可能是SQL Server服务器没有启动
2.SQL Server网络配置TCP/IP没启用
3.客户端协议中查看TCP/IP默认的端口号是不是1433
解决办法:打开sql server configuration manager
1. 在可会端协议中查看TCP/IP默认的端口号是不是1433,并保证该项启动
2. 启动SQL Server网络配置/MSSQLSERVERd的协议/ TCP/IP
3. 重新启动SQL Server服务/SQL Server(MSSQLSERVER)服务器
经过以上步骤问题应该就可以解决了
本文链接
出现这个错误,是因为插入一个长度为0的值至有外键约束的字段内。
我们来做个实验,并尝试解决它。
首先创建两个表,[dbo].[T1]是主表,[dbo].[T2]是子表,而子表的[c2]是一个有外键约束的字段。
(
col1 NVARCHAR(20) PRIMARY KEY NOT NULL,
col2 NVARCHAR(30) NULL,
col3 NVARCHAR(30) NULL
)
GO
CREATE TABLE [dbo].[T2]
(
c1 NVARCHAR(20) NOT NULL PRIMARY KEY,
c2 NVARCHAR(20) NULL FOREIGN KEY REFERENCES [dbo].[T1] ([col1]),
c3 NVARCHAR(30) NULL
)
GO
下面我们做实验,
我们再做一个实验:
什么情况?因为SQL有三值运算,TURE,FALSE 和UNKNOWN。约束其实是对满足条件,即条件表达式返回TRUE的一律通过。NULL在SQL SERVER里的类型是UNKNOWN,可以成理解为任何类型,可能为TRUE。而长度为 0的''空值,返回的将是False。
因此,我们在开SQL程序时,如果你的带有外键约束的字段,可以存储NULL值时,需要在插入的SQL语句做一些判断,就可以解决异常的出现。
本文链接
原创地址:http://www.cnblogs.com/jfzhu/archive/2012/11/23/2785269.html
转载请注明出处
SQL Server中有五种约束类型,分别是 PRIMARY KEY约束、FOREIGN KEY约束、UNIQUE约束、DEFAULT约束、和CHECK约束。查看或者创建约束都要使用到 Microsoft SQL Server Managment Studio。
1. PRIMARY KEY约束
在表中常有一列或多列的组合,其值能唯一标识表中的每一行。这样的一列或多列成为表的主键(Primary Key)。一个表只能有一个主键,而且主键约束中的列不能为空值。
查看PRIMARY KEY约束可以在object explorer中依次展开Databases –> 选择你要查看的数据库(在我的例子中是testdatabase) –> Tables –> 你要查看的表(在我的例子中是company)-> Columns
如上图所示,Primary Key 有一把金色的小钥匙。companyid 即为company表的primary key。
创建PRIMARY KEY约束可以右键点击表,然后选择Design,打开表设计器
选中column,点击上面的金色小钥匙,来创建Primary Key。
也可以右键点击column,然后选择Set Primary Key。
2. FOREIGN KEY约束
外键(Foreign Key)是用于建立和加强两个表(主表与从表)的一列或多列数据之间的连接的。创建约束的顺序是先定义主表的主键,再对从表定义外键约束。
查看FOREIGN KEY约束,展开Columns,可以看到灰色的小钥匙为Foreign Key;展开Keys,可以看到Foreign Key约束的名字为FK_contact_company。
在表设计器中,也可以点击上面的Relationships按钮,这样就可以查看到所有的Foreign Key约束
上面的例子可以看到contact 表的companyid为外键,company 表的companyid为主键。
下面来演示一下如何创建的该Foreign Key约束。
同样是点击完Relationships按钮之后,在弹出的对话框中选择Add
然后点击下面的红色圆圈内的按钮:
按下图中那样设置主表、主键和从表、外键
然后点击 OK,不要忘记保存你的设计。
3. UNIQUE约束
UNIQUE约束用于确保表中的两个数据行在非主键中没有相同的列值。与PRIMARY KEY约束类似,UNIQUE约束也强制唯一性,但UNIQUE约束用于非主键的一列或多列组合,且一个表可以定义多个UNIQUE约束,另外UNIQUE约束可以用于定义多列组合。
还以company table为例,假设我们要约束company name为唯一的,点击Manage Indexes and Keys
然后点击Add来添加Unique约束
选择column为companyname, Is Unique为Yes。
关闭并保存你的设计,这样一个Unique约束就创建好了。
4. DEFAULT约束
若在表中某列定义了DEFAULT约束,用户在插入新的数据行时,如果该列没有指定数据,那么系统将默认值赋给该列,当然该默认值也可以是空值(NULL)。
以contact表为例,在表设计器中,为性别(sex)列填写属性默认值 (‘M’)。
5. CHECK约束
CHECK约束用于限制输入一列或多列的值的范围,通过逻辑表达式来判断数据的有效性。一个列的输入内容必须满足CHECK约束的条件,否则数据无法正常输入。
还以contact表为例, 我们要限制sex列的值只能为 ´M´ 或者 ´F´。在表设计器中点击Manage Check Constraints
点击Add添加新的constraint
点击红圈内的按钮,填写表达式。我们例子中用的表达式是 SEX='M' OR SEX='F'
关闭并保存设计。向contact表中插入一行数据,如果sex列的值不为´M´ 或 ´F´, 插入就会报错。
本文链接