一、SQL模糊匹配

适用于对字符串进行模糊搜索

格式:   字段名 Like ‘%关键词%’

    

%          表示这个位置可有任意个字符(没有也可以)

%关键词%  只要包含关键词就算匹配

%关键词    以关键词结尾

关键词%    以关键词开头

关键%词    关键开头,中间不限,以词结尾

 

 

_表示任意【一个】字符

个字符,以9开头,另一个不限

 

二、基于使用Servlet开发的问题

① 当传递大量参数到服务端时,需要写很多代码将参数整理到数据模型对象中,而且需要自己做类型转换,做数据验证(是否必填、是否符合格式要求、是否长度符合要求),以及检查是否有SQL注入漏洞。这些关于参数转换、验证、格式化、安全检查需要写大量低端代码,浪费大量宝贵时间!!而且容易出bug!!!

② 每个Servlet类基本上只关联一个URL(关联来多个URL虽然可以,但Servlet中只有一套doPOST和doGET,反而会使Servlet的代码变得更复杂)。当系统比较复杂,需要处理大量业务员请求时,会产生N多Servlet类,非常不方便!

 

 

三、如何看待框架

a.  虽然直接使用JDBC和Servlet开发有很很多问题,但它们仍然设计非常优雅的开发基础。

b. 框架并没有否定JDBC和Servlet,相反,是在它们的基础上添加了很多功能,来简化开发,解决上述问题。

c. 框架总体来说分为2大派

第一派:公开的、公共的、广泛使用的开源框架,任何公司都可以使用

第二派:私有的、只在一个公司内部
使用

d. 无论是开源还是私有框架,都以JDBC和Servlet为基础,而且设计思想基本上也差不了多少(大家相互借

鉴)

四、

User

1

张三

1

2

李四

2

3

王五

2

Department

1

教学部

2

招生部

3

班主任部

user LEFT  JOIN department d  ON user.id = department.id

将department表中的对应数据填充在对应的位置,user表的行数不变

user RIGHT JOIN department ON user.id = department.id

以department表为主,将用户表中的数据对应过来,如果用户表中对应了多条,则department复制出相应的条数,最终表行数可能与department不相等(通常会多)

以上语句运行结果实例:

1 教学部  u1  u张三

2 招生部  u2  u李四

2 招生部  u3  u王五

3 班主任部 null null null

Select u*,d.* from u,d    相当于u x d (笛卡尔积)

Select d*,u.* from d,u    相当于 d x u (笛卡尔积)

Select u.*,d.* from u Inner Join d

如果希望从笛卡尔积中筛选数据,可以加 on u.xxx=d.xxx

Select u.*,d.* from u left join d On u.xxx = d.xxx

Select u.*,d.* from u right join d On u.xxx = d.xxx

五、外键

1.是一种约束条件,设计师使用外键建立表与表之间的连接关系

2.外键指定的连接有业务意义,它可以强制保持数据的对应关系,不允许意外的数据(没有对应上的数据)存在。它还可以在数据变化时,级联更新、删除或者设置Null(主表中的数据)

3.外键的存在是对关联查询(左、右、内连接等)的一种规范

4.外键保持一致的选项

Cascade    级联     当外键表中的数据变化时 

会更新 删除 主表中的数据

Set null    设置为空    当外键中的数据发生变化时

会将主表(User)中的数据设为null ,User中的数不会被删除 

No action/restrict  禁止操作    如果更新外键表时 主表中有与其关联数据

则更新操作失败 相当于未执行操作

如果非要更新  则应先将关联数据删除或者设置为其它值的方式断开关联关系

5.外键命名规则   fk_主表名_关联表名

 fk_开头,一看就知道是外键

主表名_关联表名   可以很清楚地看到是哪两个表之间关系(外键)

六、JSP中 include的用法

1.JSP的include指令可以实现JSP代码的共享应用,可以解决JSP代码重复的问题

2.代码重复会造成严重的后期维护问题,非常不利于代码的修改、升级

3.代码重复是质量差的最常见表现!是重构要消灭的第一目标

4.不断地重构消除项目中的重复代码就能够提升设计能力

、为什么做移动页面要使用谷歌浏览器

因为ios和Android系统中的浏览器都是WebKit内核

而谷歌浏览器使用的就是WebKit内核

使用Firefox的理由是:

Firefox的查看器和网络监视等工具都是中文的

JAVA基础之sql模糊匹配、外键以及jsp中include的用法的更多相关文章

  1. Java基础-SSM之mybatis一对一外键关联

    Java基础-SSM之mybatis一对一外键关联 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.准备测试环境(创建数据库表)  1>.创建husbandsfk和wife ...

  2. MySQL基础day03 存储引擎和外键MySQL 5.6

    MySQL基础day03_存储引擎和外键-MySQL 5.6 外键的条件: 1,表的存储引擎为innodb存储引擎 2,表中外键字段的类型要与参考表的字段类型一致 3,外键字段要是索引类型中的一种 M ...

  3. mysql进阶(十一)外键在数据库中的作用

    MySQL外键在数据库中的作用 MySQL外键的目的是控制存储在外键表中的数据,使两张表形成关联,是MySQL数据库中非常重要的组成部分,值得我们去深入了解.那么,MySQL外键究竟起到哪些作用呢?下 ...

  4. ssh关于含有外键的传值中无法识别正确的action的原因和解决办法

    在含有外键的表中,要保存一个值到这个外键时:逻辑思路:需要先将jsp页面的值传到相应的action中,在这个action中需要引入这个外键的实体层和DAO层(DAO层只需set方法),在执行函数中对于 ...

  5. sql模糊匹配中%、_的处理

    防sql注入之模糊匹配中%._处理: StringBuilder sbSql = new StringBuilder(); sbSql.Append(@"SELECT * from tabl ...

  6. 2016年11月17日--SQL主、外键,子查询

    主键 数据库主键是指表中一个列或列的组合,其值能唯一地标识表中的每一行.这样的一列或多列称为表的主键,通过它可强制表的实体完整性.当创建或更改表时可通过定义 PRIMARY KEY约束来创建主键.一个 ...

  7. SQL主、外键,子查询

    主键 数据库主键是指表中一个列或列的组合,其值能唯一地标识表中的每一行.这样的一列或多列称为表的主键,通过它可强制表的实体完整性.当创建或更改表时可通过定义 PRIMARY KEY约束来创建主键.一个 ...

  8. sql server 2008 外键的级联操作

    问题提出:现在我有三张表,学生Student,课程Course,成绩SC 1.  学生表Student,主键是学号Sno 2.  课程Course,主码是课程号Cno 3.  成绩SC,主码是Sno和 ...

  9. SQL Server的外键必须引用的是主键或者唯一键(转载)

    问: In SQL Server , I got this error -> "There are no primary or candidate keys in the refere ...

随机推荐

  1. Redis(七):Jedis简介和集群

    Jedis简介 1.Jedis 是Redis 客户端工具jar2.使用非集群版示例代码 Jedis jedis = new Jedis("192.168.139.132", 637 ...

  2. SCUT入门-环境搭建

    SCUT是一款基于C#且开源的游戏服务端框架,并且有一定的上线项目.最近正在入门中... 1.安装 去官网可以直接下载安装版:http://www.scutgame.com/ 源代码建议OSC Chi ...

  3. Atitit.故障排除系列-----apache 不能启动的排除

    Atitit.故障排除系列-----apache 不能启动的排除 能直接使用cli启动httpd   ,,详细打印出信息.. C:\Users\ASIMO>"C:\wamp\apach ...

  4. Java多线程简析——Synchronized(同步锁)、Lock以及线程池

    Java多线程 Java中,可运行的程序都是有一个或多个进程组成.进程则是由多个线程组成的.最简单的一个进程,会包括mian线程以及GC线程. 线程的状态 线程状态由以下一张网上图片来说明: 在图中, ...

  5. web压力测试指标

    1.TPS每秒钟完成的web请求响应数量TPS=并发数/响应时间TPS是衡量系统性能的重要指标 2.并发数时间段内,系统同时处理的web请求响应数量 3.响应时间所有web请求处理完毕的时间 4.吞吐 ...

  6. Django--缓存、信号、序列化

    一 Django的缓存机制 1.1 缓存介绍 1.缓存的简介 在动态网站中,用户所有的请求,服务器都会去数据库中进行相应的增,删,查,改,渲染模板,执行业务逻辑,最后生成用户看到的页面. 当一个网站的 ...

  7. Linux IO实时监控iostat命令详解(转载)

    简介 iostat主要用于监控系统设备的IO负载情况,iostat首次运行时显示自系统启动开始的各项统计信息,之后运行iostat将显示自上次运行该命令以后的统计信息.用户可以通过指定统计的次数和时间 ...

  8. 起航,第一个程序——还是LED灯

    如同学基本语言一样,helloworld是很多语言的第一个程序.在嵌入式开发中,点亮LED灯也是各种架构和开发板的第一个程序,其中很多东西是和单片机例如stm32是类似的,只是,现在我们没有了库函数, ...

  9. IIS短文件名泄露漏洞危害及防范方法(转)

    攻击方法(转自http://blog.sina.com.cn/s/blog_64a3795a01017xqt.html) 一直在寻找一种方法,如果我可以使用通配符"*" 和 &qu ...

  10. 一款基于jQuery和CSS3炫酷3D旋转画廊特效插件

    这是一款效果炫酷的jQuery和CSS3 3D旋转画廊特效插件.该3D画廊插件可以通过前后导航按钮来切换图片,效果就像旋转木马一样.它还带有点击放大图片,显示图片标题和用键盘操作等功能. 在线预览   ...