标签存档: 数据库

数据库设计三大范式

第一范式:当关系模式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.索引:提高查询的效率

降低更新的效率

额外消耗磁盘的效率

递归查询和其相关

先准备库数据结构:

1544691058813545.png

相关函数:

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 .="&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp";
				}				
				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;

PHP使用Redis

REmote DIctionary Server(Redis) 是一个由Salvatore Sanfilippo写的key-value存储系统。

Redis是一个开源的使用ANSI C语言编写、遵守BSD协议、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API。

它通常被称为数据结构服务器,因为值(value)可以是 字符串(String), 哈希(Map), 列表(list), 集合(sets) 和 有序集合(sorted sets)等类型。

详情请看:PHP使用Redis