sql基本介绍

一、基本的sql操作语句

1、增加,插入

插入数据关键字是INSERT INTO 表名(字段一,字段二,字段三) VALUES(值一,值二,值三);(字段是不需要加引号的,值如果是字符串需要加引号,关键字可以小写,但一般不用);

INSERT  INTO  product  (name,price,type)  VALUES  ("樱",88,"fruit") ;

2、删除

DELETE  FROM   表名   WHERE   条件语句;

3、修改(更新)

UPDATE   表名    SET   字段=“值”   WHERE    条件语句

4、查询

SELECT   *    FROM   表名   WHERE    条件语句
  • 代表所有字段;不给*可以指定字段,直接给字段名称,多个字段用逗号隔开;
    如果要统计查询出来的数据数量就用COUNT关键字来统计COUNT(*) COUNT(name)
SELECT   *   FROM   `phone`    WHERE    price >= 3000

5、条件语句

条件语句:比较运算符或者是IN()关键字(某个字段在指定的值里面),NOT IN (某个字段不在指定的值里面)
BETWEEN 值1 AND 值2 , 条件语句在值1和值2之间

SELECT   *   FROM    `phone`    WHERE    id     IN (1,8,9);

6、排序

根据条件进行排序:ORDER BY 字段 顺序(正序(ASC)倒序(DESC)),不需要加WHERE

SELECT   *   FROM   `phone`   ORDER   BY   price   DESC
SELECT   *    FROM   `phone`    WHERE    price >= 3000   ORDER     BY    price   DESC

7、限制语句

限制语句:LIMIT 值1,值2;(值不能用括号括起来)(值1:从值1开始查询,不包含值1,值2是查询的个数)
限制语句要放在最后

SELECT   *   FROM   `phone`   LIMIT   3,3
SELECT   *   FROM   `phone`    ORDER   BY   price   DESC   LIMIT   3,2

检索前5个记录行

SELECT   *   FROM   phone    LIMIT   5;

限制语句主要用来做分页:已知:1.每一页显示的条数 (例子:条数2)2.当前页数(例子:当前页3);

数据=LIMIT (当前页-1)*条数,条数

8、模糊查询

模糊查询 LIKE 前面和后面要加%

SELECT   *   FROM   `phone`    WHERE    name    LIKE     "o%" ;
SELECT   name,price    FROM    `phone`    WHERE    name   LIKE    "%e%"   ORDER   BY   price   DESC ;
SELECT   name,price    FROM    `phone`    WHERE    name    LIKE    "%e%"    AND   id>3   ORDER    BY    price    DESC ;
SELECT   *    FROM    product    WHERE    price >= 5    AND    name    LIKE    "%a%" ;

9、关联查询,联表查询

关键字 JOIN ON,这种是内联,跟INNER JOIN ON是一样的

SELECT * FROM phone JOIN product ON phone.id=product.id

左关联:LEFT JOIN ON,以左边的表为主表

SELECT * FROM phone LEFT JOIN product ON phone.id=product.id

右关联:RIGHT JOIN ON,以右边的表为主表

SELECT * FROM phone RIGHT JOIN product ON phone.id=product.id

关键字:AS

SELECT * FROM phone AS ph RIGHT JOIN product AS pr ON ph.id=pr.id;

二、连接数据库

连接数据库语法上:

  • php版本如果是5.5以上的,我们用mysqli来连接数据库,
  • 5.5或5.5以下的用mysql来连接数据库
    输出php的版本:
    echo phpinfo();

// PHP Version 5.6.14

给数据库增加数据:

1. 第一步链接数据库

php版本如果是5.5以上的:支持面向对象的写法

$link=mysqli_connect("localhost","root"," ","users");
mysqli_errno(): //判断链接数据库是否有错误
if(mysqli_errno($link)){
//抛出错误
print_r(mysqli_error($link));

}else{

echo"连接数据库成功";

}

第二步写添加sql语句:

$sql="INSERT   INTO   phone   (name,price,type)    VALUES    ('魅族',3500,'64G')";

设置编码格式:
设置编码格式方式一:

mysqli_query($link,"set names utf8");

//设置编码格式方式二:

// mysqli_set_charset($link, "utf8");

第三步执行sql语句,添加数据到数据库:

$res=mysqli_query($link, $sql);

if($res){

echo"添加成功";

}else{

echo"添加失败";

}

关闭数据库

mysqli_close($link);

//5.5或5.5以下的用mysql:面向过程写法,不支持面向对象

//mysql_connect("localhost", "root", "");

//mysql_select_db("users");

三、数据库的增、删、改、查的函数

增加、添加

function    add($sql,$database){

//连接数据库

$link=mysqli_connect("localhost","root","", $database);

//设置编码格式

mysqli_query($link,"set names utf8");

//执行sql语句

$res=mysqli_query($link, $sql);

//获取到添加数据的id

//echo mysqli_insert_id($link);

//获取前一次 MySQL 操作所影响的记录数

//echo mysqli_affected_rows($link);

return    $res;

}

//调用函数

//$sql="INSERT INTO phone (name,price,type) VALUES ('华为',2569,'p9')";

//$res=add($sql,"users");

//if($res){

//echo "添加成功";

//}else{

//echo "添加失败";

//}
删除

function   delete($sql,$database){

//连接数据库

$link=mysqli_connect("localhost","root","", $database);

//执行sql语句

$res=mysqli_query($link, $sql);

return    $res;

}

//调用删除

//$sql="DELETE FROM phone WHERE type='64G'";

//$res=delete($sql, "users");

//if($res){

//echo "删除成功";

//}else{

//echo "删除失败";

//}
更新

function   update($sql,$database){

//连接数据库

$link=mysqli_connect("localhost","root","", $database);

//设置编码格式

mysqli_query($link,"set names utf8");

//执行sql语句

$res=mysqli_query($link, $sql);

return     $res;

}

//调用更新

//$sql="UPDATE phone SET name='金米' WHERE id=8";

//$res=update($sql,"users");

//if($res){

//echo "更新成功";

//}else{

//echo "更新失败";

//}
查询
只能获取一条数据的函数:

function   getOne($sql,$database){

//连接数据库

$link=mysqli_connect("localhost","root","", $database);

//设置编码格式

mysqli_query($link,"set names utf8");

//执行sql语句,获取结果集

$result=mysqli_query($link, $sql);

//通过结果集拿到结果方式一:

$list=mysqli_fetch_assoc($result);//常用,关联数组的形式

//通过结果集拿到结果方式二:

//$list=mysqli_fetch_row($result);//索引数组的形式

//通过结果集拿到结果方式三:

//$list=mysqli_fetch_array($result);//索引数组和关联数组的形式结合

//通过结果集拿到结果方式四:

//$list=mysqli_fetch_object($result);//对象的格式

//获取查询返回的记录数;

$num=mysqli_num_rows($result);

var_dump($num);

//释放结果集

//mysqli_free_result($result);

if($list){

return    $list;

}else{

return    false;

}

}

//调用查询

//$sql="SELECT * FROM phone WHERE id=14";

//$list=getOne($sql, "users");

//print_r($list);
获取多条数据

function     getList($sql,$database){

//连接数据库

$link=mysqli_connect("localhost","root","", $database);

//设置编码格式

mysqli_query($link,"set names utf8");

//执行sql语句,获取结果集

$result=mysqli_query($link, $sql);

//通过结果集拿到结果:

while($list=mysqli_fetch_assoc($result)) {

$arr[]=$list;

}

if(!empty($arr)){

return    $arr;

}else{

return    false;

}

}

//调用查询

//$sql="SELECT * FROM phone WHERE name='华为'";

//$list=getList($sql, "users");

//echo    "<pre>";

//print_r($list);

//echo    "</pre>";
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,837评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,551评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,417评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,448评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,524评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,554评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,569评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,316评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,766评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,077评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,240评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,912评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,560评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,176评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,425评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,114评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,114评论 2 352

推荐阅读更多精彩内容

  • MySQL技术内幕:SQL编程 姜承尧 第1章 SQL编程 >> B是由MySQL创始人之一Monty分支的一个版...
    沉默剑士阅读 2,418评论 0 3
  • 什么是SQL数据库: SQL是Structured Query Language(结构化查询语言)的缩写。SQL是...
    西贝巴巴阅读 1,808评论 0 10
  • .数据库 数据库的发展: 文件系统(使用磁盘文件来存储数据)=>第一代数据库(出现了网状模型,层次模型的数据库)=...
    小Q逛逛阅读 963评论 0 2
  • 2017年7月9日星期天晴 今天下午,我、妈妈、哥哥、爸爸、表姐和表哥一起去九龙江游泳,今天是最早去九龙江游泳,水...
    曾博韬阅读 236评论 0 1
  • 创建版本库 首先,选择一个合适的地方,创建一个空目录: 此时learngit目录下会多一个.git文件,用来跟踪管...
    你说的独品阅读 292评论 0 0