数据库非空
① mysql创建表时的空值和非空值设置有什么讲究
空值是一种特殊的状态, 表示某一个字段"没有被处理过"
几乎在所有的数据库中甚至是编程语言中, 空与非空都有其存在的意义, 举个例子, 一个人员表中, 有一个年龄字段, 这个年龄字段如果为非 空, 则在不知道人员年龄的情况下, 数据无法入库, 否则会显示个奇怪的年龄(比如0岁, 或者-1岁等)
而有些情况泽不可以为空, 最常见的就是"主键", 比如身份证号之类的
② 数据库怎样设置字段非空
数据库层面的控制不太好控制吧,我是不知道怎么控制
不过,在表的层次可以控制,在创建表的时候,可以设置所有字段为非空
③ 数据库的外键何时允许为空何时不为空
数据库的外键可以为空,也可以非空,但是如果非空,则这个值必须在主表中存在。
比如主表是一个班级,主键是班级id,
字表是学生分配班级表,主键是学生id,外键是所在班级id。
如果一个学生的外键id为空,说明这个学生还没有被分配到任何一个班级
如果一个学生的外键id非空,并且是班级表中的某个id,则说明学生分配到这个班级
如果一个学生的外键id非空,并且不属于任何班级,则数据插入肯定报错。也就是说这种情况不存在。
--例子:
create table clerk(
id int,
name varchar2(10),
manager_id int);
alter table clerk add constraint pk_clerk_id primary key(id);
alter table clerk add constraint fk_clerk_manager_id foreign key(manager_id) references clerk(id);
insert into clerk values (1, 'boss', null);
insert into clerk values (2, 'zhang', null);
insert into clerk values (3, 'zhang', 2);
--、下列语句报错,因为5不是主键的值
insert into clerk values (4, 'zhang', 5);
SQL> select * from clerk;
ID NAME MANAGER_ID
---------- ---------- ----------
1 yang
2 zhang
3 zhang 2
④ 数据库中表的创建中的not null是什么意思,怎么设置
不允许这个字段为空值,写代码的话,在字符类型后面加上就可以了,例如:
create tableemp(
id varchar2(10) not null, --这个字段不能为空
name varchar2(10)
);
除了强制设定not null的,建表后,主键、分区字段等都是非空的。
(4)数据库非空扩展阅读:
not null:
comment的作用是给表创建备注,not null 意思是给字段不允许为空,是一个固定的语句表示给表创建的备注不允许为空,如果改为comment null那意思就是可以为空了。
数据库管理系统是数据库系统的核心组成部分,主要完成对数据库的操纵与管理功能,实现数据库对象的创建、数据库存储数据的查询、添加、修改与删除操作和数据库的用户管理、权限管理等。
⑤ 数据库非空约束设置
要是没有数据的话直接用以下语句即可
alter table student modify sname char(10) not null;
但是有数据的话 就不能用上面方法了,
alter table student add sname_temp char(10) not null;
update student set sname_temp=sname;
alter table drop column sname_temp;
alter table test rename column sname_temp to sname;
这种方法会使列名发生变化,而且字段顺序增加 有可能发生行迁移,对应用程序会产生影响
⑥ 数据库字段有没有必要设置非空
关键字段必须要非空。
空值有时候是有用的,比如可以简单判断该值是否为有效值。
但是有时空值会造成错误 ,一个空值数据没有任何类型,执行某些运算或显示时会出错。
所以,根据您的需要和习惯,来决定是否全部设置为非空。
对于有空值的字段,在查询和运算时一般要使用ISNULL函数给出默认值来参加运算。
一般来说:
数据值型字段用ISNULL(fieldname,0)
字值型字段用ISNULL(FIELDNAME,'')
日期型字段用ISNULL(FIELDNAME,'1900-01-01')
⑦ 数据库语句条件属性非空,备注外键怎么写
20个数据库设计最佳实践: 使用明确、统一的标明和列名,例如 School, SchoolCourse, CourceID。 数据表名使用单数而不是复数,例如 StudentCourse,而不是StudentCourses。 数据表名不要使用空格。 数据表名不要使用不必要的前缀或者后缀,例如使用School,而不是TblSchool,或者SchoolTable等等。 数据库中的密码要加密,到应用中再解密。 使用整数作为ID字段,也许现在没有这个必要,但是将来需要,例如关联表,索引等等。 使用整数字段做索引,否则会带来很大的性能问题 。 使用bit 作为布尔字段,使用整数或者varcha是浪费。同时,这类字段应该以“Is”开头。 要经过认证才能访问数据库,不要给每一个用户管理员权限。 尽量避免使用“select *”,而使用“select [required_column_list]”以获得更好的性能。 假如程序代码比较复杂,使用ORM框架,例如hibernate,iBatis。ORM框架的性能问题可以通过详细的配置去解决。 分割不常使用的数据表到不同的物理存储以获得更好的性能。 对于关键数据库,使用安全备份系统,例如集群,同步等等。 使用外键,非空等限制来保证数据的完整性,不要把所有的东西都扔给程序。 缺乏数据库文档是致命的。你应该为你的数据库设计写文档,包括触发器、存储过程和其他脚本。 对于经常使用的查询和大型数据表,要使用索引。数据分析工具可以帮助你决定如何建立索引。 数据库服务器和网页服务器应该放在不同的机器上。这回提高安全性,并减轻CPU压力。 Image和blob字段不应该定义在常用的数据表中,否则会影响性能。 范式(Normalization)要按照要求使用以提高性能。Normalization做的不够会导致数据冗余,而过度Normalization 会导致太多的join和数据表,这两种情况都会影响性能。 多花点时间在数据库设计上,否则你将来会付出加倍的时间来偿还。设置外键:方法一:SQL语句alter table 表名 add constraint 外键名 foreign key(字段名) references 主表名(字段名) on delete cascade方法二:不想写sql 语句也可以直接用图形化操作 选择你要创建外键的表,反键选择修改表
⑧ 数据库字段设计成允许空好还是非空默认值0好
从数据存储上来说,当然是设置成可为null的好了;因为null是不分配存储空间的。
可是充使用的方便性上来说,使用默认值,在很多情况下,是很方便的。
至少不要考虑为空的情况。
⑨ sql 语言中,非空语句是什么
非空语句 是不是 指
检索条件
数据库的表里面, 某个字段的值 非空?
那就是
SELECT * FROM 表 WHERE 字段 IS NOT NULL;
如果你是 创建表的时候, 要求某个字段,不能为空
那就是
CREATE TABLE 表 (
字段 数据类型 NOT NULL
);