• Flex的数据基本操作(一)


    想了解Flex有一段时间了,但因为对Java的不熟悉,迟迟找不到入门的感觉。近来比较忙,又常出差,再加上没有这一类的项目可做,比之前的未入门水平更有了退步。所以要写一个练手的东西,使用Flex、blazeds,用jtds连接SqlServer2005数据库,在使用过程中,有什么问题再说,开始干总比老是想要强一些。

    数据库中只有两个表,一个表代表班级,另一表则保存相应的学生,在界面打开时,显示班级及学生所有数据,选择某一班级时,显示对应的学生。两个表使用外键关联。界面所提供的功能还有对学生的增删改的功能,班级的就不提供了,操作和学生相同。大概功能界面如下:

    2010-6-12 14-56-43

    数据库结构:

    SET ANSI_NULLS ON
    GO
    SET QUOTED_IDENTIFIER ON
    GO
    IF NOT EXISTS (SELECT * FROM sys.objects WHERE object_id = OBJECT_ID(N'[dbo].[CLASSES]') AND type in (N'U'))
    BEGIN
    CREATE TABLE [dbo].[CLASSES](
    	[ID] [int] IDENTITY(1,1) NOT NULL,
    	[CLASSNAME] [nvarchar](20) NOT NULL,
    	[REMARK] [nvarchar](100) NULL,
     CONSTRAINT [PK_CLASS] PRIMARY KEY CLUSTERED 
    (
    	[ID] ASC
    )WITH (IGNORE_DUP_KEY = OFF) ON [PRIMARY]
    ) ON [PRIMARY]
    END
    GO
    SET ANSI_NULLS ON
    GO
    SET QUOTED_IDENTIFIER ON
    GO
    IF NOT EXISTS (SELECT * FROM sys.objects WHERE object_id = OBJECT_ID(N'[dbo].[STUDENTS]') AND type in (N'U'))
    BEGIN
    CREATE TABLE [dbo].[STUDENTS](
    	[ID] [int] IDENTITY(1,1) NOT NULL,
    	[SNAME] [nvarchar](20) NOT NULL,
    	[AGE] [int] NULL,
    	[ADDRESS] [nvarchar](50) NULL,
    	[CLASSID] [int] NOT NULL,
     CONSTRAINT [PK_STUDENTS] PRIMARY KEY CLUSTERED 
    (
    	[ID] ASC
    )WITH (IGNORE_DUP_KEY = OFF) ON [PRIMARY]
    ) ON [PRIMARY]
    END
    GO
    IF NOT EXISTS (SELECT * FROM sys.foreign_keys WHERE object_id = OBJECT_ID(N'[dbo].[FK_STUDENTS_CLASS]') AND parent_object_id = OBJECT_ID(N'[dbo].[STUDENTS]'))
    ALTER TABLE [dbo].[STUDENTS]  WITH CHECK ADD  CONSTRAINT [FK_STUDENTS_CLASS] FOREIGN KEY([CLASSID])
    REFERENCES [dbo].[CLASSES] ([ID])
    ON UPDATE CASCADE
    ON DELETE CASCADE
     
    Java与数据库的连接使用Hibernate操作,说实在话,也不太会用,只是为了图个少写代码,Hibernate.cfg.xml:
    <?xml version="1.0" encoding="UTF-8"?>
    <!DOCTYPE hibernate-configuration PUBLIC
    		"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
    		"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
    <hibernate-configuration>
        <session-factory name="MySession">
            <property name="hibernate.connection.driver_class">net.sourceforge.jtds.jdbc.Driver</property>
            <property name="hibernate.connection.password">pwd</property>
            <property name="hibernate.connection.url">jdbc:jtds:sqlserver://localhost/test</property>
            <property name="hibernate.connection.username">sa</property>
            <property name="hibernate.dialect">org.hibernate.dialect.SQLServerDialect</property>
    		<property name="current_session_context_class">thread</property>
            
            <mapping resource="hibernate.cfg.xml"/>
            <mapping resource="com/stud/Classes.hbm.xml"/>
            <mapping resource="com/stud/Students.hbm.xml"/>
        </session-factory>
    </hibernate-configuration>

    文件结构:

    2010-6-12 15-23-16 

    生成的Hibernate映射文件分别对应了两个表:

    Classes.hbm.xml内容:

    <?xml version="1.0"?>
    <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
    "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
    <!-- Generated 2010-6-11 13:58:04 by Hibernate Tools 3.2.4.GA -->
    <hibernate-mapping>
        <class name="com.stud.Classes" table="CLASSES" schema="dbo" catalog="test">
            <id name="id" type="int">
                <column name="ID" />
                <generator class="identity" />
            </id>
            <property name="classname" type="string">
                <column name="CLASSNAME" length="20" not-null="true" />
            </property>
            <property name="remark" type="string">
                <column name="REMARK" length="100" />
            </property>
            <set name="studentses" inverse="true" lazy="false" table="STUDENTS" fetch="select">
                <key>
                    <column name="CLASSID" not-null="true" />
                </key>
                <one-to-many class="com.stud.Students" />
            </set>
        </class>
    </hibernate-mapping>
     
    Students.hbm.xml内容:
    <?xml version="1.0"?>
    <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
    "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
    <!-- Generated 2010-6-11 13:58:04 by Hibernate Tools 3.2.4.GA -->
    <hibernate-mapping>
        <class name="com.stud.Students" table="STUDENTS" schema="dbo" catalog="test">
            <id name="id" type="int">
                <column name="ID" />
                <generator class="identity" />
            </id>
            <many-to-one name="classes" class="com.stud.Classes" fetch="select">
                <column name="CLASSID" not-null="true" />
            </many-to-one>
            <property name="sname" type="string">
                <column name="SNAME" length="20" not-null="true" />
            </property>
            <property name="age" type="java.lang.Integer">
                <column name="AGE" />
            </property>
            <property name="address" type="string">
                <column name="ADDRESS" length="50" />
            </property>
        </class>
    </hibernate-mapping>
  • 相关阅读:
    编程珠玑第二章阅读笔记
    第四周学习进度博客
    python的文件操作
    python通过pymysql实现数据库的增删改查
    python爬取疫情数据详解
    python基本知识点if、while、等等
    apache使用总结
    slf4j的总结
    log4j2使用总结
    安全测试总结
  • 原文地址:https://www.cnblogs.com/wjhx/p/1757174.html
Copyright © 2020-2023  润新知