Guns4.2框架,第一天的合传框架接触找不到框架里面SQL命令写在哪里,想改一下sql语句都不知道去哪里改,最好有目录

26318 条评论分享收藏感谢收起how2j.cn/tmall后台: 2. 学习思路其实呢,要在网上找一个J2EE项目是很容易的,随便在百度或者git搜索,都是一大把。 但是拿到这样的搜索来的J2EE项目,其中包含了上百个java文件,jsp文件,各种配置信息,如果没有好几个实践过的J2EE项目经验,会觉得无从看起,难以下手,最后影响学习的效果。为了使学习的曲线变得更平滑,逐渐建立学习的信心,我为这个模仿个天猫官网项目制作了由浅入深的学习教程。2.1 首先下载一个跑起来看了演示地址之后,第一步总是要下载下来,把项目配置起来,自己也跑跑看看效果的。 如果下载出来的项目不能运行,为什么要跟着你做呢?为了顺利的演示,不仅需要项目代码,还需要数据库中的数据, 所以提供了导入数据的SQL文件而导入的数据量比较大,上万条数据,使用工具导入不仅慢,还有可能出错,所以专门准备了一个命令行的方式导入,以保证导入的顺利进行配置tomcat也是比较容易出错的环节,特意准备了一个完整的server.xml,直接复制粘贴,然后启动tomcat,就一定能够成功配置了。如此这般,便可以顺利的自己也搭建一个模仿天猫的J2EE项目,在自己的机器上看到效果。2.1 由浅入深,从零开始构建整个项目 在确定了这个项目确实可用的前提下,就可以开展对这个项目的学习。但是这个项目里有许多的java,jsp.xml 等等各种类型的文件,彼此之间又有着各种关联关系,从哪里开始着手好呢? 其实,从哪里着手,都不好着手,毕竟项目有着相当的复杂度。 最好的方式,就是从零开始,由浅入深地构建出整个项目出来。从需求分析开始,明确要做哪些功能。然后分析表结构,确定什么样的表结构,表关系,可以支撑需求中的业务功能。接着再做持久层的实体类和DAO设计最后才开始进行前后台的功能开发2.2 表结构设计表结构设计是非常重要的,如果这一步没有做正确,将无法支持业务功能的需求,所以放在第一步来做。 在这部分列出了表与表之间的关系,建表的SQL语句等等。 值得一提的是,因为表比较多,为了便于理解每张表的作用,特意把表和前台页面截图做了对应,从感性上理解这些表都是干什么用的。 比如这个产品表与产品页面的截图,这样表的每个字段在界面上分别对应什么样的显示数据,对于这个表有什么用,心里就会有底很多。2.3 每个类的源代码,细致到方法级的讲解项目里有非常多的类,如实体类,DAO类,Servlet类,Filter,JSP等等,不仅每个类提供源代码,而且每个类的每个方法有什么作用,与业务有什么关系,都有细致到方法级别的讲解, 力求把代码吃透,消化明白。 2.4 业务类与界面的对应关系稍复杂的方法,还有与项目截图的一一对应关系,辅助理解。2.5 后台第一个功能精讲在功能开发环节,比如后台功能,通常来说,大部分后台功能是比较接近的,主要是业务数据的CRUD操作。 而做第一个的时候,不仅需要规范化,对于不熟悉的同学,也会略感吃力。 所以在讲解如何做后台第一个分类管理功能的时候,把其拆的特别细,碾碎到很小的颗粒,这样消化起来就容易多了。2.6 其他后台功能在完成了第一个后台功能,并消化理解之后,再做其他的后台功能就会顺畅很多2.7 前台第一个功能精讲前台功能与后台功能的做法会有区别,所以与后台功能类似的,前台第一个功能也讲得很细致,便于理解与消化2.8 其他前台功能在完成了第一个前台功能,并消化理解之后,再做其他的前台功能就会顺畅很多2.9 视频讲解光有文字讲解有时候也无法把一些较为复杂的概念、思路表达清楚。 所以在各个关键点,都有视频讲解,加深理解。3. 可运行项目
每个知识点都有当前的可运行项目下载,以确保项目一定可以运行,保障持续学习的信心。
学习一个较为复杂的项目,会有这样的体验:各个步骤差不多都跟着做了呀,但是为什么就是不能正确运行呢? 而且花很多时间,翻来覆去的改,越改越糟糕,越改越乱,犹如进入了茂密的丛林一般,几乎失去了方向。
如果进入这样的状态,真正可怕的是一点点丢失的学习的信心和动力,自然而然地开始怀疑项目本身是不是有问题喔,各种疑虑加上止步不前, 最后实在是学习不动了,只好放弃了。
其实之所以跑不出来,大部分原因都是因为某个细节没有处理好。为了面对这种情况,我特意在每个学习步骤的右上角,准备当前学习进度对应的可以运行的项目。 如果自己老是搞不出来,那么就把右上角的项目下载下来,部署,运行,就跑通了。
这样做的作用是什么呢?第1,确保了项目是可以运行的,教程没问题,打消了项目本身就有问题的疑虑第2,此时就可以把自己写的代码与“标准答案” 代码进行比较,很快就能定位自己的问题所在了。 为此还特意在对应位置,为每个源代码提供了一个文件比较功能, 方便快速定位自己哪些 “细节” 不一样。第3,定位到自己错误的地方,修改后,再回过头去部署自己的项目,并运行通过。 这样不仅技术上成长了,也能逐步增强了学习完整个项目的信心。4. 可以期待的收获看上去这个项目也不短嘛,那么真正学完这个项目后,能够得到什么呢? 4.1 典型业务场景的掌握所谓的典型业务场景就是各种商业项目里,都会有类似或者接近的功能。 在这个项目里你掌握了这些业务场景的开发,去工作之后,做类似的就能驾轻就熟。 那么都有哪些业务场景呢?4.2 设计模式的掌握设计模式的书和文章有很多,从我自己学习和工作的经验来看,如果一种设计模式,我只是在书上看过,却没有在实际工作中运用的话,那么犹如无根之树,打一把dota就忘记了,即无法深入理解其中的原理,也不能在真正工作的时候,灵活地运用到他们。而通过这个项目,基于实践所运用到的项目,就会变成你真正的技能,因为这些都会是你一行一行代码敲出来的设计模式,在面试的时候如果被问到相关问题,你也会对答如流,因为这些会是你真正“实践过”的设计模式5. 教程地址: 教程由个人完成,局限于个人的经验和视野,有诸多不足之处,请各位多多指点,谢谢。收藏的同学,请记得点个赞~赞同 1.6K104 条评论分享收藏感谢收起Guns4.2框架 怎么修改SQL语句_百度知道
Guns4.2框架 怎么修改SQL语句
答题抽奖
首次认真答题后
即可获得3次抽奖机会,100%中奖。
hefeixinhua9
来自电脑网络类芝麻团
hefeixinhua9
采纳数:892
获赞数:295
参与团队:
----增加字段ALTER TABLE T_STANDARD_COL ADD trans_state char(1);----修改字段数据,包括清楚某字段数据为nullSQL 如下:update 表名& set& 列名 = 新列值&& where 条件----修改字段类型ALTER TABLE t_user modify USER_JOB VARCHAR2(15);4.----修改字段名字&&&&原名&新名&&&&&& ALTER TABLE tmp_content_metadata RENAME COLUMN TITLE&TO5.----删除字段&&& ALTER TABLE t_user DROP COLUMN COMMENT_TIME;
为你推荐:
您可能关注的内容
个人、企业类
违法有害信息,请在下方选择后提交
色情、暴力
我们会通过消息、邮箱等方式尽快将举报结果通知您。mybatis学习总结-核心配置文件mybatis-config.xml(一) - 为程序员服务
mybatis学习总结-核心配置文件mybatis-config.xml(一)
115619 阅读
之前完成了一个mybatis的CRUD操作进行了最基本的体验。
回顾一下mybatis的步骤:
1)核心配置文件配置
2)pojo模型创建
3)映射文件配置
4)获取SqlSessionFactory
5)获取SqlSession
6)CRUD操作
7)事务操作
8)关闭SqlSession
mybatis的基本操作在这里:
这篇文章总结一下核心配置文件mybatis-config.xml的配置方法。
初体验中的mybatis-config.xml的配置:
&?xml&version=&1.0&&encoding=&UTF-8&&?&&&
&!DOCTYPE&configuration&&
&&PUBLIC&&-//mybatis.org//DTD&Config&3.0//EN&&&
&&&http://mybatis.org/dtd/mybatis-3-config.dtd&&&&
&configuration&&&
&&&&&!--&对事务的管理和连接池的配置&--&&&
&&&&&environments&default=&development&&&&
&&&&&&&&&environment&id=&development&&&&
&&&&&&&&&&&&&transactionManager&type=&JDBC&&/&&&
&&&&&&&&&&&&&dataSource&type=&POOLED&&&&
&&&&&&&&&&&&&&&&&property&name=&driver&&value=&oracle.jdbc.driver.OracleDriver&&/&&&
&&&&&&&&&&&&&&&&&property&name=&url&&value=&jdbc:oracle:thin:@localhost:1521:orcl&&/&&&
&&&&&&&&&&&&&&&&&property&name=&username&&value=&ibatis&&/&&&
&&&&&&&&&&&&&&&&&property&name=&password&&value=&ibatis&&/&&&
&&&&&&&&&&&&&/dataSource&&&
&&&&&&&&&/environment&&&
&&&&&/environments&&&
&&&&&!--&mapping&文件路径配置&--&&&
&&&&&mappers&&&
&&&&&&&&&mapper&resource=&com/yu/res/UserMapper.xml&&/&&&
&&&&&/mappers&&&
&/configuration&
Properties
由上面的配置可以看出,我们的数据库信息是直接写到了配置里
而一般情况下,对于这种配置信息,一般我们都会把它放到properties资源文件中。
1.创建一个资源文件jdbc.properties:
jdbc.driverClassName=oracle.jdbc.driver.OracleDriver
jdbc.url=jdbc:oracle:thin:@localhost:1521:orcl
jdbc.username=mybatis&&
jdbc.password=mybatis
2.mybatis-config.xml中引入
&properties&resource=&jdbc.properties&&/&
当然也可以在&properties/&标签中定义属性:
&properties&resource=&jdbc.properties&&
&property&name=&jdbc.driverClassName&&value=&oracle.jdbc.driver.OracleDriver&/&
&/properties&
3.使用properties文件里的属性
&dataSource&type=&POOLED&&&&
&&&&&&&property&name=&driver&&value=&${jdbc.driverClassName}&&/&&&
&&&&&&&property&name=&url&&value=&${jdbc.url}&&/&&&
&&&&&&&property&name=&username&&value=&${jdbc.username}&&/&&&
&&&&&&&property&name=&password&&value=&${jdbc.password}&&/&&&&
&/dataSource&
说下这些配置的加载顺序:
.在&properties&元素体内指定的属性首先被读取。
.从类路径下资源或&properties&元素的&url&属性中加载的属性第二被读取,它会&覆盖已经存在的完全一样的属性。
.作为方法参数传递的属性最后被读取,&它也会覆盖任一已经存在的完全一样的&属性,这些属性可能是从&properties&元素体内和资源/url&属性中加载的。
所以,属性的优先级为:方法直接传递参数 & 通过resource、url引用的资源 & properties元素体内定义
setting设置,关系到mybatis的主要设置,关系到mybatis运行时的行为方式。
配置方式:
&settings&&&
&&&&&&&&&setting&name=&cacheEnabled&&value=&true&&/&&&
&&&&&&&&&setting&name=&lazyLoadingEnabled&&value=&true&&/&&&
&&&&&&&&&setting&name=&multipleResultSetsEnabled&&value=&true&&/&&&
&&&&&&&&&setting&name=&useColumnLabel&&value=&true&&/&&&
&&&&&&&&&setting&name=&useGeneratedKeys&&value=&false&&/&&&
&&&&&&&&&setting&name=&autoMappingBehavior&&value=&PARTIAL&&/&&&
&&&&&&&&&setting&name=&defaultExecutorType&&value=&SIMPLE&&/&&&
&&&&&&&&&setting&name=&defaultStatementTimeout&&value=&25&&/&&&
&&&&&&&&&setting&name=&safeRowBoundsEnabled&&value=&false&&/&&&
&&&&&&&&&setting&name=&mapUnderscoreToCamelCase&&value=&false&&/&&&
&&&&&&&&&setting&name=&localCacheScope&&value=&SESSION&&/&&&
&&&&&&&&&setting&name=&jdbcTypeForNull&&value=&OTHER&&/&&&
&&&&&&&&&setting&name=&lazyLoadTriggerMethods&&value=&equals,clone,hashCode,toString&&/&&&
&&&&&/settings&
配置项说明:(从 &copy过来的 )
cacheEnabled
这个配置使全局的映射器启用或禁用 缓存。
true | false
lazyLoadingEnabled
全局启用或禁用延迟加载。当禁用时, 所有关联对象都会即时加载。 This value can be superseded for an specific relation by using the&fetchType&attribute on it.
true | false
aggressiveLazyLoading
当启用时, 有延迟加载属性的对象在被 调用时将会完全加载任意属性。否则, 每种属性将会按需要加载。
true | false
multipleResultSetsEnabled
允许或不允许多种结果集从一个单独 的语句中返回(需要适合的驱动)
true | false
useColumnLabel
使用列标签代替列名。 不同的驱动在这 方便表现不同。 参考驱动文档或充分测 试两种方法来决定所使用的驱动。
true | false
useGeneratedKeys
允许 JDBC 支持生成的键。 需要适合的 驱动。 如果设置为 true 则这个设置强制 生成的键被使用, 尽管一些驱动拒绝兼 容但仍然有效(比如 Derby)
true | false
autoMappingBehavior
指定 MyBatis 如何自动映射列到字段/ 属性。PARTIAL 只会自动映射简单, 没有嵌套的结果。FULL 会自动映射任 意复杂的结果(嵌套的或其他情况) 。
NONE, PARTIAL, FULL
defaultExecutorType
配置默认的执行器。SIMPLE 执行器没 有什么特别之处。REUSE 执行器重用 预处理语句。BATCH 执行器重用语句 和批量更新
SIMPLE REUSE BATCH
defaultStatementTimeout
设置超时时间, 它决定驱动等待一个数 据库响应的时间。
Any positive integer
Not Set (null)
safeRowBoundsEnabled
Allows using RowBounds on nested statements.
true | false
mapUnderscoreToCamelCase
Enables automatic mapping from classic database column names A_COLUMN to camel case classic Java property names aColumn.
true | false
localCacheScope
MyBatis uses local cache to prevent circular references and speed up repeated nested queries. By default (SESSION) all queries executed during a session are cached. If localCacheScope=STATEMENT local session will be used just for statement execution, no data will be shared between two different calls to the same SqlSession.
SESSION | STATEMENT
jdbcTypeForNull
Specifies the JDBC type for null values when no specific JDBC type was provided for the parameter. Some drivers require specifying the column JDBC type but others work with generic values like NULL, VARCHAR or OTHER.
JdbcType enumeration. Most common are: NULL, VARCHAR and OTHER
lazyLoadTriggerMethods
Specifies which Object's methods trigger a lazy load
A method name list separated by commas
equals,clone,hashCode,toString
defaultScriptingLanguage
Specifies the language used by default for dynamic SQL generation.
A type alias or fully qualified class name.
org.apache.ibatis.scripting.xmltags.XMLDynamicLanguageDriver
callSettersOnNulls
当结果集中含有Null值时是否执行映射对象的setter或者Map对象的put方法。此设置对于原始类型如int,boolean等无效。
true | false
Specifies the prefix string that MyBatis will add to the logger names.
Any String
Specifies which logging implementation MyBatis should use. If this setting is not present logging implementation will be autodiscovered.
SLF4J | LOG4J | LOG4J2 | JDK_LOGGING | COMMONS_LOGGING | STDOUT_LOGGING | NO_LOGGING
proxyFactory
Specifies the proxy tool that MyBatis will use for creating lazy loading capable objects.
CGLIB | JAVASSIST
typeAliases
类型别名。
给java类型取一个别名,方便在核心配置、映射配置中来使用这个java类型。
在& 中的UserMapper.xml配置中,有这样的配置信息:
&select&id=&findUserById&&resultType=&com.yu.model.User&&parameterType=&long&&&&
&&&&&&&&select&*&from&t_user&where&id&=&#{id}
可以看到resultType属性的值为com.yu.model.User,表示这个查询返回的类型为com.yu.model.User类型。
如果有很多种类型的话,每次都得把类型的全路径写上,感觉就很费事。
所以就可以用mybatis提供的typeAliases来进行别名配置。
在核心配置文件中加上配置:
&typeAliases&&&
&&&&&&&typeAlias&type=&com.yu.model.User&&alias=&User&&/&
&&&&&&&typeAlias&type=&com.yu.model.Org&&alias=&Org&/&
&/typeAliases&
然后修改UserMapper.xml的配置:
&select&id=&findUserById&&resultType=&User&&parameterType=&long&&&&
&&&&&&&&select&*&from&t_user&where&id&=&#{id}
这样就简便多了。
当然,这是对于我们自定义的类型,或者其他类型,用这种设置别名的方式。
其实mybatis给我们提供了很多内建的类型别名,使我们不用在typeAliases中指定,就可以直接使用,下面是mybatis中内建的别名:
映射的类型
BigDecimal
bigdecimal
BigDecimal
collection
Collection
typeHandlers
类型处理器。
1)获取数据库的值,以合适的方式转变为对应的java类型
2)将java类型,以合适的方式转化为数据库的保存类型
mybatis中默认的类型处理器:
类型处理器
BooleanTypeHandler
java.lang.Boolean,&boolean
任何兼容的布尔值
ByteTypeHandler
java.lang.Byte,&byte
任何兼容的数字或字节类型
ShortTypeHandler
java.lang.Short,&short
任何兼容的数字或短整型
IntegerTypeHandler
java.lang.Integer,&int
任何兼容的数字和整型
LongTypeHandler
java.lang.Long,&long
任何兼容的数字或长整型
FloatTypeHandler
java.lang.Float,&float
任何兼容的数字或单精度浮点型
DoubleTypeHandler
java.lang.Double,&double
任何兼容的数字或双精度浮点型
BigDecimalTypeHandler
java.math.BigDecimal
任何兼容的数字或十进制小数类型
StringTypeHandler
java.lang.String
CHAR 和 VARCHAR 类型
ClobTypeHandler
java.lang.String
CLOB 和 LONGVARCHAR 类型
NStringTypeHandler
java.lang.String
NVARCHAR 和 NCHAR 类型
NClobTypeHandler
java.lang.String
NCLOB 类型
ByteArrayTypeHandler
任何兼容的字节流类型
BlobTypeHandler
BLOB 和 LONGVARBINARY 类型
DateTypeHandler
java.util.Date
TIMESTAMP 类型
DateOnlyTypeHandler
java.util.Date
TimeOnlyTypeHandler
java.util.Date
SqlTimestampTypeHandler
java.sql.Timestamp
TIMESTAMP 类型
SqlDateTypeHandler
java.sql.Date
SqlTimeTypeHandler
java.sql.Time
ObjectTypeHandler
其他或未指定类型
EnumTypeHandler
Enumeration Type
VARCHAR-任何兼容的字符串类型, 作为代码存储(而不是索引)
EnumOrdinalTypeHandler
Enumeration Type
Any compatible&NUMERIC&or&DOUBLE, as the position is stored (not the code itself).
当然也可以自定义类型处理器,
比如有一个字段的值是一个逗号隔开的字符串,如果希望查询结果映射到java类型时是一个数组,而保存到数据库时又会是以逗号隔开的字符串。
这种情况需要自定义类型处理器来处理。
关于自定义类型处理器,会单独做一个总结。
在&&中的UserMapper.xml配置中,有这样的配置信息:
&&!--&mapping&文件路径配置&--&&&
&&mappers&&&
&&&&&&mapper&resource=&com/yu/res/UserMapper.xml&&/&&&
&&/mappers&
用于引用定义好的映射定义,告诉mybatis去哪里找我们的sql定义配置。有以下几种用法:
直接引用xml文件
&mappers&&&
&&&&&&mapper&resource=&com/yu/res/UserMapper.xml&&/&&&
&/mappers&
通过绝对路径引用,注意在绝对路径前加上:“file:///”
&mappers&&&
&&&&&&mapper&url=&file:///D:/workspace/mywork/MyBatis/src/com/yu/res/UserMapper.xml&/&&
&/mappers&
引用mapper接口对象的方式:
&mappers&&&
&&&&&&mapper&resource=&com.yu.mapper.UserMapper&&/&&&
&/mappers&
引用mapper接口包的方式:
&mappers&&&
&&&&&&package&name=&com.yu.mapper&/&
&/mappers&
这篇文章介绍了mybatis核心配置文件mybatis-config.xml的一些基本配置。
还没有总结完,比如environments和其他的配置,下一篇文章专门说明environments和剩下的配置
声明: 本文采用
协议进行授权 | 转载请注明转自《》
积一时之硅步,臻千里之遥程。
原文地址:, 感谢原作者分享。
您可能感兴趣的代码}

我要回帖

更多关于 ssh框架与ssm区别 的文章

更多推荐

版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。

点击添加站长微信