第一范式:当关系模式R的所有属性都不能在分解为更基本的数据单位时,称R是满足第一范式的,简记为1NF。满足第一范式是关系模式规范化的最低要求,否则,将有很多基本操作在这样的关系模式中实现不了。
第二范式:如果关系模式R满足第一范式,并且R得所有非主属性都完全依赖于R的每一个候选关键属性,称R满足第二范式,简记为2NF。
第三范式:设R是一个满足第一范式条件的关系模式,X是R的任意属性集,如果X非传递依赖于R的任意一个候选关键字,称R满足第三范式,简记为3NF。
第一范式:当关系模式R的所有属性都不能在分解为更基本的数据单位时,称R是满足第一范式的,简记为1NF。满足第一范式是关系模式规范化的最低要求,否则,将有很多基本操作在这样的关系模式中实现不了。
第二范式:如果关系模式R满足第一范式,并且R得所有非主属性都完全依赖于R的每一个候选关键属性,称R满足第二范式,简记为2NF。
第三范式:设R是一个满足第一范式条件的关系模式,X是R的任意属性集,如果X非传递依赖于R的任意一个候选关键字,称R满足第三范式,简记为3NF。
1.函数—创建—调用—变量 (临时变量declare,用户变量set @xx=xx,系统变量@@)
创建,调用,删除
有返回值的sql语句中都不能够执行除了select 。。。into之外
2.存储过程—创建—查看—调用—删除
参数的类型 in out inout类型的参数 通过out类型的参数可以给存储过程实现返回值
存储过程中 可以执行任意的sql语句,更到的灵活,在实际开发中使用更多
相同点:减少网络流量的消耗
3.视图—创建—调用—删除
数据库中存在的虚表
4.事务:安全的更新数据库的一中方式
四大特征:原子性,一致性,隔离性,持久性
三个操作指令 begin commit rollbacl
1.手动开启事务,手动提交事务
2.成功之后,进行提交,一旦提交不能够车脚
3.失败之后,执行回滚操作,回滚去除脏数据
事务是面向当前连接的
事务更新大批量数据的时候,效率高,更新安全(脏数据)
5.索引:提高查询的效率
降低更新的效率
额外消耗磁盘的效率
先准备库数据结构:

相关函数:
function get_cates($pid=0,$cates=array(),$level=0){
$result = get_by_name("category","pid=$pid");
if(!empty($result)){
foreach($result as $value){
$str = "";
for($i=0;$i<$level;$i++){
$str .="<span color='red'>-</span>";
}
$value['name'] = $str.$value['name'];
$cates[] = $value;
$cates = get_cates($pid=$value['id'],$cates,$level+1);
}
}
return $cates;
}
//根据当前id查出其所有子类id
function get_ids($dir,$id,$results = array()){
$result = get_by_name($dir,"pid=$id");
if(!empty($result)){
for($i=0;$i<count($result);$i++){
$id = $result[$i]["id"];
$results[] = $result[$i];
$results = get_ids($dir,$id,$results);
}
}
return $results;
}
//将数据追加成多维格式
function get_arr($pid=0,$cates=array()){
$result = get_by_name("category","pid=$pid");
if(!empty($result)){
foreach($result as $key=>$value){
$cates[$key] = $value;
if(empty($cates[$key]['child'])){
$cates[$key]['child'] = array();
}
$cates[$key]['child'] = get_arr($value['id'],$cates[$key]['child']);
}
}
return $cates;
}
//递归遍历
function arr_foreach($dt,$level=0){
echo "<ul>";
foreach($dt as $key=>$value){
$str = "";
for($i=0;$i<$level;$i++){
$str .="        ";
}
foreach($value as $key=>$val){
if($key == "name"){
echo "<li><a href='#'><font color='#EB05B0' size='18px'>".$str.$val."</font></a></li>";
}else if($key=="child" && count($val) > 0){
arr_foreach($val,$level+1);
}
}
}
echo "</ul>";
}
一、获取页面中所有form的文本值并打包(下文省略部分代码):
var forms = $(".warpper1").find("form");
var arr = new Object();
for(var i=0;i<forms.length;i++){
var id = forms.eq(i).attr("id");
arr[id] = $("#"+id).serializeArray();
}
console.table(arr);
$.ajax({
url:'/Home/Members/perfect_now',
data:arr,
dataType:'html',
type:'post',
success:function(data){
console.log(data);
}
});
二、将后台获取的$_POST转化成易于插入数据库表的数据结构:
//print_r($_POST);
foreach($_POST as $k=>$v){
$num = 0;
foreach($v as $key=>$val){
if($val['name'] == $v[0]['name'] && $key != 0){
++$num;
}
$_POST[$k][$num][$val['name']] = $val['value'];
if($key != $num){unset($_POST[$k][$key]);}
unset($_POST[$k][$num]['name']);
unset($_POST[$k][$num]['value']);
}
}
//print_r($_POST);exit;
REmote DIctionary Server(Redis) 是一个由Salvatore Sanfilippo写的key-value存储系统。
Redis是一个开源的使用ANSI C语言编写、遵守BSD协议、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API。
它通常被称为数据结构服务器,因为值(value)可以是 字符串(String), 哈希(Map), 列表(list), 集合(sets) 和 有序集合(sorted sets)等类型。
详情请看:PHP使用Redis
近期评论