php教程 php手册 第十五章 MySQL 数据库

第十五章 MySQL 数据库

Jun 13, 2016 am 09:37 AM
aspnet 소프트웨어 프로그래밍

学习要点:
1.Web 数据库概述
2.MySQL 的操作
3.MySQL 常用函数
4.SQL 语句详解
5.phpMyadmin

 

一.Web数据库概述

  现在,我们已经熟悉了PHP 的基础知识,这是我们想暂时离开PHP 一章,来重点介绍
一下关系型数据库,让大家了解数据库比文件储存的有点。这些优点包括:
1.关系型数据库比普通文件的数据访问速度更快。
2.关系型数据库更容易查阅并提取满足特定条件的数据。
3.关系型数据库更具有专门的内置机制处理并发访问,作为程序员,不需要为此担心。
4.关系型数据库可以提供对数据的随即访问。
5.关系型数据库具有内置的权限系统。

 

关系数据库的概念
  至今为止,关系数据库是最常用的数据库类型。在关系代数方面,它们具有很好的理论
基础。当使用关系数据库的时候,并不需要了解关系理论(这是一件好事),但是还是需要
理解一些关于数据库的基本概念。

1)表格
  关系数据库由关系组成,这些关系通常称为表格。顾名思义,一个关系就是一个数据的
表格。电子数据表就是一种表格。

2)列
  表中的每一列都有惟一的名称,包含不同的数据。此外,每一列都有一个相关的数据类
型。
3)行
  表中的每一行代表一个客户。每一行具有相同的格式,因而也具有相同的属性。行也成
为记录。
4)值

  每一行由对应每一列的单个值组成。每个值必须与该列定义的数据类型相同。
5)键
  每一条数据所对应的唯一的标识。
6)模式
  数据库整套表格的完整设计成为数据库的模式。
7)关系
  外键标识两个表格数据的关系。
  如何设计Web 数据库
  1)考虑要建模的实际对象。
  2)避免保存冗余数据。
  3)使用原子列值(对每一行的每个属性只存储一个数据。)
  4)选择有意义的键。
  5)考虑需要询问数据库的问题。
  6)避免多个空属性的设计


Web 数据库架构
浏览器和Web 服务器之间的通信:

浏览器和PHP&MySQL 服务器之间的通信

1)用户的Web 浏览器发出HTTP 请求,请求特定Web 页面。
2)Web 服务器收到.php 的请求获取该文件,并将它传到PHP 引擎,要求它处理。
3)PHP 引擎开始解析脚本。脚本中有一条连接数据库的命令,还有执行一个查询的命令。
PHP 打开通向MYSQL 数据库的连接,发送适当的查询。
4)MYSQL 服务器接收数据库查询并处理。将结果返回到PHP 引擎。
5)PHP 以你去哪干完成脚本运行,通常,这包括将查询结果格式化成HTML 格式。然
后再输出HTML 返回到Web 服务器。
6)Web 服务器将HTML 发送到浏览器。

 

二.MySQL操作

登录到MySQL
1)打开MySQL Command Line Client
2)输入root 的设置密码

MySQL 常规命令

1)显示当前数据库的版本号和日期。
  SELECT VERSION(),CURRENT_DATE();
2)通过AS 关键字设置字段名。
  SELECT VERSION() AS version; //可设置中文,通过单引号
3)通过SELECT 执行返回计算结果
  SELECT (20+5)*4;
4)通过多行实现数据库的使用者和日期
  >SELECT
  >USER()
  >,
  >NOW()
  >;
5)通过一行显示数据库使用者和日期
  >SELECT USER();SELECT NOW();
6)命令的取消
  >\c
7)MySQL 窗口的退出
  >exit;

 

MySQL 常用数据类型

整数型:TINYINT,SMALLINT,INT,BIGINT
浮点型:FLOAT,DOUBLE,DECIMAL(M,D)
字符型:CHAR,VARCHAR
日期型:DATETIME,DATE,TIMESTAMP
备注型:TINYTEXT,TEXT,LONGTEXT

 

MySQL 数据库操作
1)显示当前存在的数据库
  >SHOW DATABASES;
2)选择你所需要的数据库
  >USE guest;
3)查看当前所选择的数据库
  >SELECT DATABASE();
4)查看一张表的所有内容
  >SELECT * FROM guest; //可以先通过SHOW TABLES;来查看有多少张表
5)根据数据库设置中文编码
  >SET NAMES gbk; //set names utf8;
6)创建一个数据库

  >CREATE DATABASE book;
7)在数据库里创建一张表
  >CREATE TABLE users (
  >username VARCHAR(20), //NOT NULL 设置不允许为空
  >sex CHAR(1),
  >birth DATETIME);
8)显示表的结构
  >DESCIRBE users;
9)给表插入一条数据
  >INSERT INTO users (username,sex,birth) VALUES ('Lee','x',NOW());
10)筛选指定的数据
  > SELECT * FROM users WHERE username = 'Lee';
11)修改指定的数据
  >UPDATE users SET sex = '男' WHERE username='Lee';
12)删除指定的数据
  > DELETE FROM users WHERE username='Lee';
13)按指定的数据排序
  > SELECT * FROM users ORDER BY birth DESC; //正序
14)删除指定的表
  >DROP TABLE users;
15)删除指定的数据库
  >DROP DATABASE book;

 

三.MySQL常用函数

 

四.SQL语句详解

1.创建一个班级数据库school,里面包含一张班级表grade,包含编号(id)、姓名(name)、
邮件(email)、评分(point)、注册日期(regdate)。
mysql>CREATE DATABASE school; //创建一个数据库
mysql> CREATE TABLE grade (
  //UNSIGNED 表示无符号,TINYINT(2) 无符号整数0-99,NOT NULL 表示不能为
空,AUTO_INCREMENT 表示从1 开始没增加一个字段,累计一位
  -> id TINYINT(2) UNSIGNED NOT NULL AUTO_INCREMENT,
  -> name VARCHAR(20) NOT NULL,
  -> email VARCHAR(40),
  -> point TINYINT(3) UNSIGNED NOT NULL,
  -> regdate DATETIME NOT NULL,
  -> PRIMARY KEY (id) //表示id 为主键,让id 值唯一,不得重复。
  -> );

2.给这个班级表grade 新增5-10 条学员记录
mysql> INSERT INTO grade (name,email,point,regdate) VALUES
('Lee','yc60.com@gmail.com',95,NOW());

3.查看班级所有字段的记录,查看班级id,name,email 的记录
mysql> SELECT * FROM grade;

mysql> SELECT id,name,email FROM grade;

4.姓名等于'Lee'的学员,成绩大于90 分的学员,邮件不为空的成员,70-90 之间的成员
  mysql> SELECT * FROM grade WHERE name='Lee';
  mysql> SELECT * FROM grade WHERE point>90;
  mysql> SELECT * FROM grade WHERE email IS NOT NULL;
  mysql> SELECT * FROM grade WHERE point BETWEEN 70 AND 90;
  mysql> SELECT * FROM grade WHERE point IN (95,82,78);
5.查找邮件使用163 的学员,不包含yc60.com 字符串的学员
  mysql> SELECT * FROM grade WHERE email LIKE '%163.com';
  mysql> SELECT * FROM grade WHERE email NOT LIKE '%yc60.com%';
6.按照学员注册日期的倒序排序,按照分数的正序排序
  mysql> SELECT * FROM grade ORDER BY regdate DESC;
  mysql> SELECT * FROM grade ORDER BY point ASC;
7.只显示前三条学员的数据,从第3 条数据开始显示2 条
  mysql> SELECT * FROM grade LIMIT 3;
  mysql> SELECT * FROM grade LIMIT 2,2;
8.修改姓名为'Lee'的电子邮件
  mysql> UPDATE grade SET email='yc60.com@163.com' WHERE name='Lee';

9.删除编号为4 的学员数据
  mysql> DELETE FROM grade WHERE id=4;

 

10.过一遍以上的分组函数
    略。
11.检查这个表的信息
  mysql> SHOW TABLE STATUS \G;
12.优化一张表
  mysql> OPTIMIZE TABLE grade;

 

五.PhpMyAdmin

phpMyAdmin(简称PMA)是一个用PHP 编写的,可以通过互联网在线控制和操作
MySQL。他是众多MySQL 管理员和网站管理员的首选数据库维护工具,通过phpMyAdmin
可以完全对MySQL 数据库进行操作。


创建数据库scholl
创建一个数据库->选择utf8 字符集


导出另一个数据库SQL
1.选择另一个数据库->导出
2.选择需要导出的表->全选
3.选择Add DROP TABLE / DROP VIEW (基本表一旦删除,表中的数据以及相应建立
的索引和视图都将自动被删除)
4.选择另存为文件
5.选择执行,保存sql 文件


导入数据库
1.选择被导入的数据库
2.选择Import(导入),选择sql 文件

3.执行即可

 

 

重建表
1.找到sql 文件中的刚才输出的建表语句.
2.复制建表语句
3.然后选择sql,选择粘贴,执行即可


修复数据表
1.选择要修复的表
2.在选中项中,选择修复表,即可


优化数据表
1.选择要优化的表
2.在选中项中,选择优化表,即可


修改,删除,插入表记录

执行SQL 语句

 

 注:文章出自李炎恢PHP视频教程,本文仅限交流使用,不得用于商业用途,否则后果自负。

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 채팅 명령 및 사용 방법
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

Vue.js와 ASP.NET의 조합은 웹 애플리케이션의 성능 최적화 및 확장을 위한 팁과 제안을 제공합니다. Vue.js와 ASP.NET의 조합은 웹 애플리케이션의 성능 최적화 및 확장을 위한 팁과 제안을 제공합니다. Jul 29, 2023 pm 05:19 PM

Vue.js와 ASP.NET의 결합은 웹 애플리케이션의 성능 최적화와 확장을 위한 팁과 제안을 제공합니다. 웹 애플리케이션의 급속한 발전으로 인해 성능 최적화는 개발자에게 필수적이고 중요한 작업이 되었습니다. 인기 있는 프런트 엔드 프레임워크인 Vue.js를 ASP.NET과 결합하면 더 나은 성능 최적화 및 확장을 달성하는 데 도움이 될 수 있습니다. 이 문서에서는 몇 가지 팁과 제안 사항을 소개하고 몇 가지 코드 예제를 제공합니다. 1. HTTP 요청 감소 HTTP 요청 수는 웹 애플리케이션의 로딩 속도에 직접적인 영향을 미칩니다. 통과하다

생성 AI가 소프트웨어 개발을 변화시키는 10가지 방법 생성 AI가 소프트웨어 개발을 변화시키는 10가지 방법 Mar 11, 2024 pm 12:10 PM

번역기 | 검토자: Chen Jun | Chonglou 1990년대에 사람들이 소프트웨어 프로그래밍을 언급할 때 이는 일반적으로 편집기를 선택하고 코드를 CVS 또는 SVN 코드 베이스로 확인한 다음 코드를 실행 파일로 컴파일하는 것을 의미했습니다. Eclipse 및 Visual Studio와 같은 해당 통합 개발 환경(IDE)은 프로그래밍, 개발, 문서화, 구성, 테스트, 배포 및 기타 단계를 완전한 소프트웨어 개발 수명 주기(SDLC)에 통합하여 개발자의 작업 효율성을 향상시킬 수 있습니다. 최근 몇 년 동안 널리 사용되는 클라우드 컴퓨팅 및 DevSecOps 자동화 도구는 개발자의 포괄적인 역량을 향상시켜 더 많은 기업이 소프트웨어 애플리케이션을 보다 쉽게 ​​개발, 배포 및 유지 관리할 수 있게 되었습니다. 오늘날 생성적 AI는 차세대 개발입니다.

ASP.NET 프로그램의 MySQL 연결 풀 사용 및 최적화 기술 ASP.NET 프로그램의 MySQL 연결 풀 사용 및 최적화 기술 Jun 30, 2023 pm 11:54 PM

ASP.NET 프로그램에서 MySQL 연결 풀을 올바르게 사용하고 최적화하는 방법은 무엇입니까? 소개: MySQL은 고성능, 안정성 및 사용 용이성을 특징으로 널리 사용되는 데이터베이스 관리 시스템입니다. ASP.NET 개발에서는 데이터 저장을 위해 MySQL 데이터베이스를 사용하는 것이 일반적인 요구 사항입니다. 데이터베이스 연결의 효율성과 성능을 향상시키기 위해서는 MySQL 연결 풀을 올바르게 사용하고 최적화해야 합니다. 이 기사에서는 ASP.NET 프로그램에서 MySQL 연결 풀을 올바르게 사용하고 최적화하는 방법을 소개합니다.

ASP.NET 프로그램에서 MySQL에 다시 연결하는 방법은 무엇입니까? ASP.NET 프로그램에서 MySQL에 다시 연결하는 방법은 무엇입니까? Jun 29, 2023 pm 02:21 PM

ASP.NET 프로그램에서 MySQL에 다시 연결하는 방법은 무엇입니까? ASP.NET 개발에서는 MySQL 데이터베이스를 사용하는 것이 매우 일반적입니다. 그러나 네트워크나 데이터베이스 서버 문제로 인해 데이터베이스 연결이 중단되거나 타임아웃되는 경우가 있습니다. 이 경우, 프로그램의 안정성과 신뢰성을 보장하기 위해 연결이 끊어진 후 연결을 다시 설정해야 합니다. 이 기사에서는 ASP.NET 프로그램에서 MySQL 연결을 다시 연결하는 방법을 소개합니다. 필요한 네임스페이스를 먼저 참조하려면 코드 파일의 헤드에서 참조하세요.

Vue.js와 ASP.NET의 결합으로 엔터프라이즈급 애플리케이션의 개발 및 배포가 가능합니다. Vue.js와 ASP.NET의 결합으로 엔터프라이즈급 애플리케이션의 개발 및 배포가 가능합니다. Jul 29, 2023 pm 02:37 PM

Vue.js와 ASP.NET의 결합을 통해 엔터프라이즈급 애플리케이션의 개발 및 배포가 가능해졌습니다. 오늘날 빠르게 발전하는 인터넷 기술 분야에서 엔터프라이즈급 애플리케이션의 개발 및 배포가 점점 더 중요해지고 있습니다. Vue.js와 ASP.NET은 프런트엔드 및 백엔드 개발에 널리 사용되는 두 가지 기술을 결합하면 엔터프라이즈 수준 애플리케이션의 개발 및 배포에 많은 이점을 가져올 수 있습니다. 이 기사에서는 Vue.js 및 ASP.NET을 사용하여 코드 예제를 통해 엔터프라이즈 수준 애플리케이션을 개발하고 배포하는 방법을 소개합니다. 먼저, 설치해야 합니다.

ASP.NET 프로그램에서 MySQL 연결 풀을 올바르게 구성하고 사용하는 방법은 무엇입니까? ASP.NET 프로그램에서 MySQL 연결 풀을 올바르게 구성하고 사용하는 방법은 무엇입니까? Jun 29, 2023 pm 12:56 PM

ASP.NET 프로그램에서 MySQL 연결 풀을 올바르게 구성하고 사용하는 방법은 무엇입니까? 인터넷의 발달과 데이터 양의 증가로 인해 데이터베이스 접속 및 연결에 대한 수요도 증가하고 있습니다. 데이터베이스의 성능과 안정성을 향상시키기 위해서는 커넥션 풀링(Connection Pooling)이 필수적인 기술이 되었습니다. 이 기사에서는 ASP.NET 프로그램에서 MySQL 연결 풀을 올바르게 구성하고 사용하여 데이터베이스의 효율성과 응답 속도를 향상시키는 방법을 주로 소개합니다. 1. 커넥션 풀링의 개념과 기능 커넥션 풀링은 데이터베이스 커넥션을 재사용하는 기술이다.

ASP.NET에서 MySQL 연결 풀의 트랜잭션 성능 사용 및 최적화 ASP.NET에서 MySQL 연결 풀의 트랜잭션 성능 사용 및 최적화 Jun 30, 2023 pm 12:12 PM

ASP.NET 프로그램에서 MySQL 연결 풀의 트랜잭션 성능을 올바르게 사용하고 최적화하는 방법은 무엇입니까? ASP.NET 프로그램에서 데이터베이스 트랜잭션은 매우 중요한 부분입니다. 트랜잭션은 데이터베이스의 일관성과 무결성을 보장하는 동시에 더 나은 성능을 제공합니다. MySQL 데이터베이스를 사용하는 경우 연결 자원을 관리하고 성능을 최적화하기 위해 연결 풀을 사용하는 것이 필수적입니다. 먼저 MySQL 커넥션 풀의 개념을 간략하게 이해해보자. 연결 풀은 특정 수의 연결을 사전 초기화하여 만든 버퍼 풀입니다.

aspnet에 내장된 개체는 무엇입니까? aspnet에 내장된 개체는 무엇입니까? Nov 21, 2023 pm 02:59 PM

ASP.NET의 기본 제공 개체에는 "요청", "응답", "세션", "서버", "응용 프로그램", "HttpContext", "Cache", "Trace", "Cookie" 및 "Server.MapPath": 1. 클라이언트가 발행한 HTTP 요청을 나타내는 요청 2. 응답: 웹 서버가 클라이언트에 반환한 HTTP 응답을 나타냅니다. 클라이언트 등

See all articles