分类 Database 下的文章

NUMERIC和DECIMAL的区别是什么?

decimal(numeric ) 同义,用于精确存储数值 。

decimal 数据类型最多可存储 38 个数字,所有数字都能够放到小数点的右边。

decimal 数据类型存储了一个准确(精确)的数字表达法;不存储值的近似值。


定义 decimal 的列、变量和参数的两种特性如下:

  p 小数点左边和右边数字之和,不包括小数点。如 123.45,则 p=5,s=2。指定精度或对象能够控制的数字个数。

  s 指定可放到小数点右边的小数位数或数字个数。

p 和 s 必须遵守以下规则:0 <= s <= p <= 38。numeric 和 decimal 数据类型的默认最大精度值是 38。

在 Transact-SQL 中,numeric 与 decimal 数据类型在功能上等效。当数据值一定要按照指定精确存储时,可以用带有小数的 decimal 数据类型来存储数字。

转换 decimal 和 numeric 数据对于 decimal 和 numeric 数据类型,Microsoft® SQL Server™ 将精度和小数位数的每个特定组合看作是不同的数据类型。例如,decimal(5,5) 和 decimal(5,0) 被当作不同的数据类型。

在 Transact-SQL 语句中,带有小数点的常量自动转换为 numeric 数据值,且必然使用最小的精度和小数位数。


例如,常量 12.345 被转换为 numeric 值,其精度为 5,小数位为 3。

从 decimal 或 numeric 向 float 或 real 转换会导致精度损失。

从 int、smallint、tinyint、float、real、money 或 smallmoney 向 decimal 或 numeric 转换会导致溢出。


默认情况下,在将数字转换为较低精度和小数位数的 decimal 或 numeric 值时,SQL Server 使用舍入法。

然而,如果 SET ARITHABORT 选项为 ON,当发生溢出时,SQL Server 会出现错误。若仅损失精度和小数位数,则不会产生错误。

Hibernate(JPA)中异常not-null property references a null or transient value解决方法

一个不能为空的属性引用了一个空值或游离状态的值.

如:有不为null的字段在删除时却为null,就报这种错误了

方案1、将.hbm.xml文件中cascade设成all,也就是父表记录删除,与父表关联的子表记录都删除(根据具体情况来取舍)

方案2,删除父表时,先解除子表与父表的关联关系,再删除父表记录(根据具体情况来取舍

异常1:not-null property references a null or transient value解决方法:将“一对多”关系中的“一”方,not-null设置为false

异常2:org.hibernate.TransientObjectException: object references an unsaved transient instance解决方法:cascade="save-update,persist"

异常3:org.hibernate.QueryException: could not resolve property解 决方法:"from Category category where category.userID = :userID"修改为"from Category category where userID = :userID"或者"from Category category where category.user.id = :userID"

异常4:could not initialize proxy - the owning Session was closed

解决方法:设置lazy为false

MySQL数据库中创建函数报“ERROR 1418 ”错误,不能创建函数的解决方法

我们在使用MySQL数据库开发项目的时候,有时MySQL系统自带的函数不能完全满足我们开发的需要,解决方法是自己创建函数,可以有可能在你创建函数的过程事会报出Error 1418错误

对于报这种错误的详细信息如所所示

ERROR 1418 (HY000): This function has none of DETERMINISTIC, NO SQL, or READS SQL DATA in its declaration and binary logging is enabled (you *might* want to use the less safe log_bin_trust_function_creators variable)
ERROR 1418 (HY000): This function has none of DETERMINISTIC, NO SQL, or READS SQL DATA in its declaration and binary logging is enabled (you *might* want to use the less safe log_bin_trust_function_creators variable)

MySQL函数不能创建,是未开启功能。

解决方法:MySQL函数不能创建,是未开启功能:

mysql> show variables like '%func%';
+---------------------------------+-------+
| Variable_name | Value |
+---------------------------------+-------+
| log_bin_trust_function_creators | OFF |
+---------------------------------+-------+
1 row in set (0.00 sec)

mysql> set global log_bin_trust_function_creators=1;
Query OK, 0 rows affected (0.00 sec)

mysql> show variables like '%func%';
+---------------------------------+-------+
| Variable_name                            | Value   |
+---------------------------------+-------+
| log_bin_trust_function_creators  | ON |
+---------------------------------+-------+
1 row in set (0.00 sec)mysql>

如果上方法不能成功解决mysql中的ERROR 1418错误,那还得请你使用下面方法试试:

第一步: mysql> SET GLOBAL log_bin_trust_function_creators = 1;

第二步: 系统启动时 --log-bin-trust-function-creators=1

第三步: 在my.ini(Linux下为my.conf)文件中 [mysqld] 标记后加一行内容为 log-bin-trust-function-creators=1

Windows系统下Apache搭配PHP5支持MySQL

今天在机器上配好apache2.0.x+php5+mysql5,部署帝国cms系统的时候,结果发现php5默认是不支持mysql的。于是便打开php.ini文件,查找extension=php_mysql.dll,把前面的分号去掉,重启apache,报错找不到php_mysql.dll。这点困难吓不到我,找到extension_dir指向到ext所在的目录,然后把libmysql.dll拷贝到系统system32目录下,重启apache,成功了。