如何将mysql数据库表中的内容显示在Web页面中,用什么软件实现呢?

如何将mysql数据库表中的内容显示在Web页面中,用什么软件实现呢?,第1张

可以采用SSH的开发框架,将mysql数据库的驱动等相关信息写到框架中,编写配置文件,映射文件等,然后在html或者jsp页面上编写相应的字段,在tomcat中加载相应的页面就能进行显示。

建的如果是java项目,只需要引入mysql-connector-java-5.1.10-bin.jar就可以运行java项目。建的如果是web工程,当Class.forName("com.mysql.jdbc.Driver")时,Eclipse是不会去查找字符串,不会去查找驱动。所以需要把mysql-connector-java-5.1.10-bin.jar拷贝到tomcat下lib目录下,然后,右键【工程】,点击【properties】,然后点击【Java Build Path】,点击【Add External Jars...】,从tomcat下lib目录中选择对应的mysql-connector-java-5.1.10-bin.jar,如下图所示,然后点击【OK】即可。

需要三个步骤:第一步,用php连接数据库;

第二步,用sql语句查询数据并把查询出来的结果存入到一个数组或对象中。

第三步,显示数据。

下面我就用面向过程的编程方式来显示数据。这里我用网页中的表格来显示数据。你可以根据你自己的需要来选择显示的方式。

<?php

$conn=mysql_connect("localhost","用户名",”密码“) //连接数据库,用户名、密码即数据库的用户名和密码

mysql_select_db("数据库名")//选择你要查询的数据库的名称

mysql_query(”SET NAMES 'gbk'“)//设置查询的数据库数据编码,根据数据库的编码设置

$sql="select * from user"//比如说你要查询一个用户表user,假设它有三个字段,用户id,用户名username,密码password,

$rs=mysql_query($sql)

?>

<table width="400" border="1" style="text-align:center">

<tr><th>用户ID</th><th>用户名</th><th>密码</th></tr>

<?php

while($row=mysql_fetch_assoc($rs)){

?>

<tr><td><?php echo $row['id']?></td><td><?php echo $row['username']?></td><td><?php echo $row['password']?></td></tr>

<?php

}

?>

</table>

# SELECT 数据查询

## 基础

显示如何使用简单的`select`语句查询单个表中的数据 使用`SELECT`语句从表或视图获取数据。

表由行和列组成,如电子表格。 通常,我们只希望看到子集行,列的子集或两者的组合。

SELECT语句的结果称为结果集,它是行列表,每行由相同数量的列组成。

select 语法

SELECT语句由以下列表中所述的几个子句组成:

1. SELECT 之后是逗号分隔列或星号(*)的列表,表示要返回所有列。

2. FROM 指定要查询数据的表或视图。

3. JOIN 根据某些连接条件从其他表中获取数据。

4. WHER E过滤结果集中的行。

5. GROUP BY将一组行组合成小分组,并对每个小分组应用聚合函数。

6. HAVING 过滤器基于GROUP BY子句定义的小分组。

7. ORDER BY 指定用于排序的列的列表。

8. LIMIT 限制返回行的数量。

语句中的`SELECT`和`FROM`语句是必须的,其他部分是可选的。

`SELECT`语句允许通过在`SELECT`子句中指定逗号分隔列的列表来查询表的部分数据

建议显式获取数据的列,原因如下:

1. 使用星号(*)可能会返回不使用的列的数据。 它在MySQL数据库服务器和应用程序之间产生不必要的I/O磁盘和网络流量。

2. 如果明确指定列,则结果集更可预测并且更易于管理。 想象一下,当您使用星号(*)并且有人通过添加更多列来更改表格数据时,将会得到一个与预期不同的结果集。

3. 使用星号(*)可能会将敏感信息暴露给未经授权的用户

格式 `select 列筛选 form table where 行筛选`

还有一些有用的运算符可以在WHERE子句中使用来形成复杂的条件,例如:

>BETWEEN 选择在给定范围之内的值。

>LIKE 匹配基于模式匹配的值。

>IN 指定值是否匹配列表中的任何值。

>IS NULL 检查该值是否为NULL。

## SELECT 子查询

在一个查询过程中 嵌套另一个查询,子查询的结果作为外部查询的条件或者数据范围来使用。

分为 3 类:

1. where 型

- `select展示列名 from 表名 where 列名 运算符[in...] (select 对应列名 from ...)`

- 这个列名 和 对应列名 应该做到类型相同

- 如果不加入运算符 也可使用IN 这些类似的符号 - `select 展示列名 from 表名 where 列名 in (select 对应列名 from ...)`

- ex:

`select 展示列名 from 表名 where 列名 >ALL(select 对应列名 from ....)`

比子查询的值都大

`select 展示列名 from 表名 where 列名 >ANY(select 对应列名 from ....)`

比子查询的任意一个值大

2. from 型

- `select 展示列名 from 表名 inner join (select 列名 from ...) 临时表名 on 条件;`

- 其中,select的子查询所得的表 为临时表,后跟临时表名,可在条件判断中指代

3. exist 型

- `select 展示列 from 表名 where exists (select 列名 from 表名 where 条件)`

- 将主查询的结果带入子查询进行条件判断和匹配,如果查询出结果即保留。

## 去重 DISTINCT

SELECT 语句执行简单的数据查询时,返回的是所有匹配的记录。`distinct` 实现查询不重复的数据

**DISTINCT 关键字的主要作用就是对数据表中一个或多个字段重复的数据进行过滤,只返回其中的一条数据给用户。**

使用 `DISTINCT` 关键字时需要注意以下几点:

- `DISTINCT` 关键字只能在 `SELECT` 语句中使用。

- 在对一个或多个字段去重时,`DISTINCT` 关键字必须在所有字段的最前面。

- 如果 `DISTINCT` 关键字后有多个字段,则会对多个字段进行组合去重,也就是说,只有多个字段组合起来完全是一样的情况下才会被去重。

## 指定别名 AS

### 1. 为表指定别名

1. 当表名很长的时候 或者 执行了一些特殊的查询的时候,为方便 *** 作,可以为表指定一个别名,用以替代原来的名称

2. 语法.

3. `表名>as 别名>` - 含义: - `表名>` : 数据库中存储的数据表名称。

- `别名>` : 查询的时候指定的新的名称。

- `as` : 此关键字 可以 省略,省略之后要将 `表名`与`别名`用 `空格` 分开

** *注意:表的别名不能与该数据库的其它表同名。字段的别名不能与该表的其它字段同名。在条件表达式中不能使用字段的别名,否则会出现“ERROR 1054 (42S22): Unknown column”这样的错误提示信息。* **

*** ex1:

***

### 2. 为字段指定别名

1. 在使用 SELECT 语句查询数据时,MySQL 会显示每个 SELECT 后面指定输出的字段。有时为了显示结果更加直观,我们可以为字段指定一个别名。

2. 语法:

3. `字段名>[AS] 别名>`

- 含义:

- `字段名>`:为数据表中字段定义的名称。

- `字段别名>`:字段新的名称。

- `AS` 关键字可以省略,省略后需要将字段名和别名用空格隔开

** *注意:表别名只在执行查询时使用,并不在返回结果中显示。而字段定义别名之后,会返回给客户端显示,显示的字段为字段的别名* ** ***

ex2:

***

## 限制查询条数 LIMIT

1. LIMIT 关键字有 3 种使用方式,即

- `指定初始位置`、

- `不指定初始位置`

- `OFFSET 组合`使用

(。。。。。 我之前一直不知道, 只会使用 `limit 200`。。。。。)

### 指定初始位置

1. 语法

- `LIMIT 初始位置,记录数`

- 初始位置”表示从哪条记录开始显示;第一条记录的位置是 0,第二条记录的位置是 1。后面的记录依次类推。

- “记录数”表示显示记录的条数。

- *LIMIT 后的两个参数必须都是正整数。

*ex:tb_students_info 表中,使用 LIMIT 子句返回从第 4 条记录开始的行数为 5 的记录,SQL 语句和运行结果如下。

### 不指定初始位置

记录从第一条记录开始显示。显示记录的条数由 LIMIT 关键字指定。

1. 语法

- `LIMIT 5`

- `SELECT * FROM tb_students_info LIMIT 15`

### LIMIT 和 OFFSET 组合使用

1. 语法

- `LIMIT 记录数 OFFSET 初始位置`

- 参数和 LIMIT 语法中参数含义相同,“初始位置”指定从哪条记录开始显示;“记录数”表示显示记录的条数。

该语句返回的是从第 4 条记录开始的之后的 5 条记录。即“ LIMIT 5 OFFSET 3 ”意思是获取从第 4 条记录开始的后面的 5 条记录,和“ LIMIT 3 , 5 ”返回的结果相同。

*** 2021-12-22 今天先学到这里 明天继续 MySql 的查询 学习


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/8537368.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-17
下一篇 2023-04-17

发表评论

登录后才能评论

评论列表(0条)

保存