这个系统中,可以添加雇员,添加部门;查看所有的部门信息和雇员信息;可以管理部门的雇员。

create database empanddept;
use empanddept
create table emp(id int(20) auto_increment PRIMARY key , name varchar(20),salary float,age int,dept int(20));

create table dept(id int(20) auto_increment PRIMARY key , name varchar(20),description varchar(50),leader int(20));

其中department表中的字段id与employee表中的字段department是一对多的关系。其中employee表
将还没有分配的雇员存放在temp部门中。

这个系统中,可以添加雇员,添加部门;查看所有的部门信息和雇员信息;可以管理部门的雇员,例如:添加或删除雇员.
难度增加:
难度一:一个雇员只能在一个部门.
难度二:如果雇员从部门删除,它将被放到部门名为临时部门中,在临时部门中的雇员表示还没有分配部门.
难度三:将ID改为字符串型,并实现自增
难度四:每个部门都有一个部门管理员.管理员是本部门的一名员工
难度五:实现批量删除
难度六:实现分页
难度七:实现模糊查询
难度八:实现多条件查询
难度九:实现Ajax增删改查

开发工具:MyEclipse. 或 Eclipse
数据库:mysql.
数据库名:empanddept.
两张表:(1)emp,(2)dept




将雇员添加到部门



在部门中选择要添加的雇员:

<table align="center" bgcolor="#008800" border="0" cellspacing="2" cellpadding="5">
     <tr bgcolor="#cccccc">
    <td>ID</td><td>姓名</td><td>添加</td>
  </tr>

   <tr>
     <form action="" method="get">
       <tr bgcolor="#FFFF88">
       <td>
         www
        </td>
        <td>
         www
        </td>
        <td><input type="submit" value="确定"></td>
      </tr>
     </form>
   </tr>

 </table>






部门管理应用




<%@ page contentType="text/html; charset=GBK" %>



增加部门



增加部门:







<tr  bgcolor="#FFFF88">
  <td>name:
  </td>
  <td><input type="text" name="name" size="20">
  </td>
</tr>

<tr  bgcolor="#FFFF88">
  <td>description:
  </td>
  <td><input type="text" name="description" size="20">
  </td>
  </tr>

  <tr bgcolor="#FFFF88">
    <td>leader:
    </td>
    <td><input type="text" name="leader" size="20">
    </td>
  </tr>

  <tr  bgcolor="#FFFF88">
    <td colspan="2" align="center"><input type="submit" value="submit">
    </td>
  </tr>

id:




<%@ page contentType="text/html; charset=GBK" %>



增加雇员



增加雇员:

id:
name:
salary:
age:
department:


<%@ page contentType="text/html;charset=gb2312"%>



选择要删除的员工


在部门中选择要删除的雇员:












 </table>




<%@ page contentType="text/html; charset=GBK" %>



部门添加成功



部门添加成功




<%@ page contentType="text/html; charset=GBK" %>



查看所有的部门



以下是系统的所有部门:

ID 姓名 删除

www

www






     </tr>







 </table>




<%@ page contentType="text/html; charset=GBK" import="java.util.*" %>




部门ID 部门名称 部门领导 增加员工 删除员工

www

www

www
添加 删除









</table>


<%@ page contentType="text/html; charset=GBK"%>




雇员添加成功




雇员添加成功

successful!





<%@ page contentType="text/html;charset=gb2312"%>




增加一个雇员
增加一个部门
管理部门员工
查看所有雇员信息
查看所有部门信息



<%@ page contentType="text/html; charset=GBK" %>







<%@ page contentType="text/html;charset=gb2312"%>








<%@ page contentType="text/html; charset=GBK" import="java.util.*" %>




所有部门信息




所有部门信息:


部门ID 部门名称 部门领导 增加雇员 删除雇员
www www www 添加 删除








</table>




<%@ page contentType="text/html; charset=GBK" import="java.util.*" %>




所有雇员信息




所有雇员信息:


部门ID 姓名 领导 描述
www www www www



    <td>www</td>
   <td>www</td>
   <td>www</td>
    <td>www</td>
    <td>www</td>
</tr>

</table>



以上是需要用到的14个jsp
求助源代码要怎么写,一点头绪都没有

ID 姓名 年龄 月薪 所在部门

1个回答

源代码的话是需要页面代码还是后台代码,还是全部都要?建议去github找一些开源的封装好前端框架的代码.自己跑起来之后,可以根据自己的需求进行代码的修改和优化

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
怎么 查询出所有雇员中已经工作了20年的所有雇员的基本信息 呢?
## **_雇佣日期:HIREDATE_** ![图片说明](https://img-ask.csdn.net/upload/201911/09/1573266536_80786.png) ## **_在MySQL数据库里怎么写查询语句呢?谢谢大佬回复。回复后会采纳耶!_**
mysql中查询出所有雇员的姓名及其所属上级的姓名
![图片说明](https://img-ask.csdn.net/upload/201911/07/1573111543_226638.png) 能解释一下select ename,(select ename from t_emp b where b.empid = a.mgr) as 领导 from t_emp a;的意思吗?? 本来是在一张表里查询,但为啥感觉这样写变成了两张表? 查询结果(没列完): ![图片说明](https://img-ask.csdn.net/upload/201911/07/1573111889_664070.png)
JSP性别编辑JSP性别编辑JSP性别编辑
代码如下,emp_sex是整形的,怎样编辑JSP使sex=1是显示男,sex=0是显示女 ``` <table border="" cellspacing="" cellpadding="" align="center"> <tr> <th>雇员编号</th> <th>雇员职位</th> <th>雇员姓名</th> <th>雇员性别</th> <th>雇员年龄</th> <th>所属部门</th> <th>雇员工龄</th> </tr> <c:forEach items="${requestScope.data.employee}" var="post"> <tr> <th>${post.emp_id }</th> <th>${post.post.post_name}</th> <th>${post.emp_name }</th> <th>${post.emp_sex }</th> <th>${post.emp_age }</th> <th>${post.emp_depart }</th> <th>${post.emp_year }</th> </tr> </c:forEach> </table> ```
数据库oraclede代码代码运行有问题
3.某公司要根据雇员的职位来加薪,公司决定按下列加薪结构处理: job_id 加薪 ----------------------- Clerk 500 Salesman 1000 Analyst 1500 Otherwise 2000 编写一个程序块,接受一个雇员名,从employees表中实现上述加薪处理. DECLARE v_ename hr.employees.last_name%type:='&v_ename'; v_job hr.employees.job_id%type; v_addSal hr.employees.salary%type;--额外增加的工资 v_sal hr.employees.salary%type; BEGIN select job_id into v_job from hr.employees where last_name = v_ename; select salary into v_sal from hr.employees where last_name = v_ename; IF v_job = 'SH_CLERK' then v_addSal := 500; elsif v_job = 'SA_MAN' then v_addSal := 1000; elsif v_job = 'AD_SST' then v_addSal := 1500; else v_addSal := 2000; END IF; v_addSal := v_addSal + v_sal; UPDATE hr.employees SET salary = v_addSal where last_name = v_ename; END; 运行结果为
如何用SQL实现这个功能
在ORACLE SQL中,有两个TABLE,一个是顾客,一个是雇员 每个雇员有一个或多个顾客, 如何筛选出有多于或者等于2个顾客的雇员?
SQL读取某行某字段的问题.
在ORACLE SQL中,我想实现以下功能: 在某个指定行中,寻找某个特定字段的值,并输出拥有所有次特定字段行. 例如: 一个表有以下属性:雇员姓名,雇员老板 我想查找'王五'的老板(这里假设是张三),并输出所有老板的名字为张三的雇员.
oracle 的问题怎么解决求答案
select emp.ename,dept.dname from emp,dept where emp.deptno=dept.deptno and emp.deptno=10 union all select dept.dname from dept; 查询块具有不正确的结果列数 为什么应该怎么改 显示部门10 的所有雇员名、部门名以及其 他部门名??????????????????????????
oracle中游标的使用方法
使用下面的SQL语句创建一个临时表top_dogs,用于保存雇员的姓名和工资。 CREATE TABLE top_dogs ( name VARCHAR2(25), salary NUMBER(11,2)); 【要求】创建一PL/SQL块,检索出工资水平在前几名的雇员的姓名及工资(如果有多名雇员工资相同的情况,则每一个雇员都占n名中的一个名额,即最后只输出n个人)。 (1)通过SQL*Plus替代变量读取要检索的雇员人数n。 (2)通过循环,从EMP表中获取前n名的雇员的姓名及工资。(提示:rownum获得当前行行号) (3)将检索出的雇员姓名和工资写入TOP_DOGS表。 (4)测试特殊情况,例如n=0或者n大于雇员总数。每次向TOP_DOGS写入数据前清空该表。 求教!!!
Oracle数据库的自定义函数
创建一个通过雇员编号返回雇员名称及上级名称的函数get_emp_name,注意异常问题
单位工资计算软件问题
某公司财务需要开发一个计算雇员工资的程序。 该公司有3类员工。 工人 工资为每小时工资额乘当月工作时数再加上工龄工资; 销售人员 工资为每小时工资额乘当月工作时数加上销售额提成再加上工龄 工资,其中,销售额提成等于该销售人员当月售出商品金额的1%; 管理人员 工资为基本工资再加上工龄工资。 请用面向对象方法分析、设计这个程序,并用C++语言写出完整的程序。 举例: 员工工号:键盘输入 员工类型:键盘输入 参加工作时间:键盘输入 工人工资: 每小时工资额:宏定义80元/小时 月工作时数:键盘输入 工龄工资:第一年50元/月(宏定义),以后每年以20%递增,比如1978年参加工作,1979年为50+50*0.2=60元 月总工资 = 每小时工资额*月工作时数+工龄工资 输出:工号、月工作时数、总工资 要求: 可以同时输入输出多位员工信息
单位工资计算软件问题怎么解决
某公司财务需要开发一个计算雇员工资的程序。 该公司有3类员工。 工人 工资为每小时工资额乘当月工作时数再加上工龄工资; 销售人员 工资为每小时工资额乘当月工作时数加上销售额提成再加上工龄 工资,其中,销售额提成等于该销售人员当月售出商品金额的1%; 管理人员 工资为基本工资再加上工龄工资。 请用面向对象方法分析、设计这个程序,并用C++语言写出完整的程序。 举例: 员工工号:键盘输入 员工类型:键盘输入 参加工作时间:键盘输入 工人工资: 每小时工资额:宏定义80元/小时 月工作时数:键盘输入 工龄工资:第一年50元/月(宏定义),以后每年以20%递增,比如1978年参加工作,1979年为50+50*0.2=60元 月总工资 = 每小时工资额*月工作时数+工龄工资 输出:工号、月工作时数、总工资 要求: 可以同时输入输出多位员工信息
关于java中preparedStatement的一个小问题(很简单!跪求!)
goods表字段为number(文本,主键) name(文本) madeTime(日期) price(数字,双精度) **_AddRecord.java_** ``` import java.sql.*; public class AddRecord { String databaseName=""; //数据库名 String tableName=""; //表名 String number="", //商品号 name="", //名称 madeTime; //生产日期 double price; //价格 public AddRecord() { try{ Class.forName("org.apache.derby.jdbc.EmbeddedDriver"); } catch(ClassNotFoundException e) { System.out.print(e); } } public void setDatabaseName(String s) { databaseName=s.trim(); } public void setTableName(String s) { tableName=s.trim(); } public void setNumber(String s) { number=s.trim(); } public void setName(String s) { name=s.trim(); } public void setPrice(double n) { price=n; } public void setMadeTime(String b) { madeTime=b; } public String addRecord() { String str=""; Connection con; PreparedStatement sql; //预处理语句 try { String uri="jdbc:derby:"+databaseName+";create=true"; con=DriverManager.getConnection(uri); String insertCondition="INSERT INTO "+tableName+" VALUES (?,?,?,?)"; sql=con.prepareStatement(insertCondition); if(number.length()>0) { sql.setString(1,number); sql.setString(2,name); sql.setString(3,madeTime); sql.setDouble(4,price); int m=sql.executeUpdate(); if(m!=0) str="对表中添加"+m+"条记录成功"; else str="添加记录失败"; } else { str="必须要有雇员号"; } con.close(); } catch(SQLException e) { str="没有提供添加的数据或"+e; } return str; } } ``` **_Test.java_** ``` public class Example11_10 { public static void main(String args[]) { AddRecord insertRecord=new AddRecord(); String database="shop"; String tableName="goods"; insertRecord.setDatabaseName(database); insertRecord.setTableName(tableName); insertRecord.setNumber("D001"); insertRecord.setName("联想电脑"); insertRecord.setMadeTime("2015-12-10"); insertRecord.setPrice(5600); String backMess=insertRecord.addRecord(); System.out.println(backMess); } } ``` 为什么prepareStatement方法中insert语句的in参数,在set第三个日期时是setString而不是setDate,我知道madeTime定义是String类型,但是为什么可以用setString来对应日期类型字段?
Java初学一枚 一个小程序 求有人帮我看看
package malnAV; public class Work3_3 { public static void main(String[] args) { //??? //方法 main 不能声明为“静态”;只能在静态类型或顶级类型中才能声明静态方法 Emp e1=new Emp(001,"张三"); Emp e2=new Emp(002,"李四"); Emp e3=new Emp(003,"王五"); Doc d1=new Doc(001,"会计"); e1.setMino(e3); e2.setMino(e3);//e3为e1,e2的领导 e1.setDoc(d1); e2.setDoc(d1); e3.setDoc(d1);//e1,e2,e3同属d1部门 d1.setEmp(new Emp[]{e1,e2,e3}); System.out.println(e1.tell()); System.out.println(e2.tell()); System.out.println(e3.tell()); } } class Emp{//雇员 private int no ; private String name; private Emp mgr; private Doc doc; public Emp(){ } public Emp(int no,String name){ this.no=no; this.name=name; } public int getNo() { return no; } public void setNo(int no) { this.no = no; } public String getName() { return name; } public void setName(String name) { this.name = name; } public Emp getMino() { return mgr; } public void setMino(Emp mino) { this.mgr = mino; } public Doc getDoc() { return doc; } public void setDoc(Doc doc) { this.doc = doc; } public String tell(){ if(this.mgr.getName()!=null){ return "雇员编号:"+this.no+",姓名:"+this.name+",领导:" +this.mgr.getName()+",部门:"+this.doc.getName(); } else{ return "雇员编号:"+this.no+",姓名:"+this.name+",部门:"+this.doc.getName(); } } class Doc{//部门 private int no; private String name; private Emp []emp; public Doc(){ } public Doc(int no,String name){ this.no=no; this.name=name; } public int getNo() { return no; } public void setNo(int no) { this.no = no; } public String getName() { return name; } public void setName(String name) { this.name = name; } public Emp[] getEmp() { return emp; } public void setEmp(Emp[] emp) { this.emp = emp; } public String tell(){ return this.no+"部门"+this.name+"部"; } }
C++类公司人员管理 运行报错
#include<iostream> #include<string> using namespace std; /*class Data { int year; int month; int day; public: void setyear(int year){ this->year=year; }void setmonth(int month){ this->month=month ; }void setday(int day){ this->day=day; }void getyear(){ cout << year; } void getmonth(){ cout << month; }void getday( ){ cout << day; } };*/ class employee { protected: char *name; //姓名 int individualEmpNo; //个人编号 int grade; //级别 float accumPay; //月薪总额 static int employeeNo; //本公司职员编号目前最大值 //Data data; public: employee(); //构造函数 ~employee(); //析构函数 virtual void pay() = 0; //计算月薪函数(纯虚函数) virtual void promote(int increment); //升级函数(虚函数) virtual void displayStatus() = 0; //显示人员信息(纯虚函数) }; class technician :public employee //兼职技术人员类 { private: float hourlyRate; //每小时酬金 int workHours; //当月工作时数 public: technician(); //构造函数 void promote(int); //升级函数 void pay(); //计算月薪函数 void displayStatus(); //显示人员信息 }; class salesman :virtual public employee //兼职推销员类 { protected: float CommRate; //按销售额提取酬金的百分比 float sales; //当月销售额 public: salesman(); //构造函数 void promote(int); //升级函数 void pay(); //计算月薪函数 void displayStatus(); //显示人员信息 }; class manager :virtual public employee //经理类 { protected: float monthlyPay; //固定月薪数 public: manager(); //构造函数 void promote(int); //升级函数 void pay(); //计算月薪函数 void displayStatus(); //显示。人员信息 }; class salesmanager :public manager, public salesman //销售经理类 { public: salesmanager(); //构造函数 void promote(int); //升级函数' void pay(); //计算月薪函数 void displayStatus(); //显示人员信息 }; int employee::employeeNo = 1000; //员工编号基数为 employee::employee( ) { char namestr[50]; //输人雇员姓名时首先临时存放在namestr中 cout << "请输入下一个雇员的姓名:"; cin >> namestr; getchar(); name = new char[strlen(namestr) + 1]; //动态申请用于存放姓名的内存空间 strcpy_s(name,51, namestr); //将临时存放的姓名复制到name /*int y, m, d; cout << "请输入该雇员的生日" << endl; cin >> y; data.setyear(y); cin >> m; data.setmonth(m); cin >> d; data.setday(d);*/ individualEmpNo = employeeNo++; //新输入的员工,其编号为目前最大编号加l grade = 1; //级别初值为l accumPay = 0.0; //月薪总额初值为 } employee::~employee() { delete name; //在析构函数中删除为存放姓名动态分配的内存空间 } void employee::promote(int increment) { grade += increment; //升级,提升的级数由increment指定 } technician::technician() { hourlyRate = 100; //每小时酬金元 } void technician::promote(int) { employee::promote(2); //调用基类的升级函数,升级 } void technician::pay() { cout << "请输入" << name << "本月的工作时数:"; cin >> workHours; accumPay = hourlyRate*workHours;//计算月薪,按小时计酬 cout << "兼职技术人员" << name << "编号" << individualEmpNo << "本月工资" << accumPay << endl; } void technician::displayStatus() { cout << "兼职技术人员" << name << "编号" << individualEmpNo << "级别为" << grade << "级,已付本月工资" << accumPay; /*cout << "出生日期为:"; data.getyear(); data.getmonth(); data.getday();*/ } salesman::salesman() { CommRate = 0.04; //销售提成比例% } void salesman::promote(int) { employee::promote(0); //调用基类的升级函数,升级 } void salesman::pay() { cout << "请输人" << name << "本月的销售额:"; cin >> sales; accumPay = sales*CommRate; //月薪二销售提成 cout << "推销员" << name << "编号" << individualEmpNo << "本月工资" << accumPay << endl; } void salesman::displayStatus() { cout << "推销员" << name << "编号" << individualEmpNo << "级别为" << grade << "级,已付本月工资" << accumPay; /*cout << "出生日期为:"; data.getyear(); data.getmonth(); data.getday();*/ } manager::manager() { monthlyPay = 8000; //固定月薪元 } void manager::promote(int) { employee::promote(3); //调用基类的升级函数,升级 } void manager::pay() { accumPay = monthlyPay; //月薪总额即固定月薪数 cout << "经理" << name << "编号" << individualEmpNo << "本月工资" << accumPay << endl; } void manager::displayStatus() { cout << "经理" << name << "编号" << individualEmpNo << "级别为" << grade << "级,已付本月工资" << accumPay; /*cout << "出生日期为:"; data.getyear(); data.getmonth(); data.getday();*/ } salesmanager::salesmanager() { monthlyPay = 5000; CommRate = 0.005; } void salesmanager::promote(int) { employee::promote(2); //调用基类的升级函数,升级 } void salesmanager::pay() { cout << "请输入" << employee::name << "所管辖部门本月的销售总额:"; cin >> sales; accumPay = monthlyPay + CommRate*sales; //月薪二固定月薪+销售提成 cout << "销售经理" << name << "编号" << individualEmpNo << "本月工资" << accumPay << endl; } void salesmanager::displayStatus() { cout << "销售经理" << name << "编号" << individualEmpNo << "级别为" << grade << "级,已付本月工资" << accumPay; /*cout << "出生日期为:"; data.getyear(); data.getmonth(); data.getday();*/ } int main() { manager m1; technician t1; salesmanager sm1; salesman s1; employee *emp[4] = { &m1, &t1, &sm1, &s1 }; //用指针数组的各元素存放各对象的地址 int i; for (i = 0; i<4; i++) { /*依次调用各派生类对象的成员函数,完成各自不同的升 级、计算月薪、显示信息功能。*/ emp[i]->promote(0); emp[i]->pay(); emp[i]->displayStatus(); } return 0; } 一运行 输入姓名之后就报错~我看半天了 都觉得挺对啊 求大神指点
JAVA使用继承和多态解决公司支出的总薪水问题
abstract class Employee { public abstract double earnings(); } class YearWorker extends Employee { //重写earnings()方法 } class MonthWorker extends Employee { //重写earnings()方法 } class WeekWorker extends Employee { //重写earnings()方法。 } class Company { Employee[] employee; double salaries=0; Company(Employee[] employee) { this.employee=employee; } public double salariesPay() { //计算salaries。 } } public class CompanySalary { public static void main(String args[]) { Employee [] employee=new Employee[29]; //公司有29名雇员 for(int i=0;i<employee.length;i++) { //雇员简单地分成三类 if(i%3==0) employee[i]=new WeekWorker(); else if(i%3==1) employee[i]=new MonthWorker(); else if(i%3==2) employee[i]=new YearWorker(); } Company company=new Company(employee); System.out.println("公司薪水总额:"+company.salariesPay()+"元"); } } 上述代码中要重写earnings方法,和计算salaries,怎么做呀,资料的讲解不会,要是增加多增加一种雇员该怎么改代码?
JSP,mysql,tomcat,罕见中文乱码问题from textarea?
最近在上手学javaweb,根据书里的练习题要做一个雇员系统,其中有一项是用textarea输入雇员的简介,大概就是一个页面输入信息,然后通过submit传值到另一个页面用javabean 接收,接收方式是setProperties的自动设置,然后在数据库里更新信息。 然后最开始出现了类似Incorrect string value: '\xE6\xB1\x9F\xE5\xAE\x81...' for column ‘note' 的错误信息,所以我就尝试单独设置note,用iso8859-1解码再编码再设置,解码后就不再报错了,但是会出现乱码,而且不管我用任何编码方式都是乱码,并且其他text都没有乱码唯独textarea有。我尝试过GBK,UTF-8,重新用iso8859-1,甚至latin1都试过了还是乱码,我就佛了。 下面 是一些或许会有用的信息:数据库连接的url里相关信息是useUnicode=true&characterEncoding=GBK;request.setCharacterEncoding("GBK")或者UTF-8都试过,set和不set都试过,form是get和post都试过,JSP文件最上面那几个charset=UTF-8和=GBK都试过,数据库里character_set_client=gbk, character_set_connection=gbk, character_set_databse=latin1, character_set_filesystem=binary, character_set_results=gbk, character_set_server =latin1, character_set_system=utf8;然后还试过在textarea里加入属性style="word-break:break-all;word-wrap: break-word;",不过貌似是为了解决换行问题的,反正也是没用。噢,最后提一下,这个textarea的乱码不是一堆看不懂的字符,就是纯粹的???,不知道这个信息有没有用,希望有大神来解答一下小弟的问题,不胜感激。
java数据库登陆界面,在最下面的ActionPerformed中,数据库的语句是不是有错?
import java.awt.*; import java.awt.event.*; import javax.swing.*; import javax.swing.event.*; import java.util.*; import java.sql.*; public class Login extends Frame implements ActionListener { JLabel Labelusernumber=new JLabel("用户名:"); JLabel Labelpassword=new JLabel("密码:"); JLabel Labelshenfen=new JLabel("身份:"); JTextField TextFieldusernumber=new JTextField(); JPasswordField FieldPassword=new JPasswordField(); JButton button=new JButton("登录"); JComboBox JC=new JComboBox(); public Login() { setTitle("超市销售信息管理系统"); setLayout(null); Labelusernumber.setBounds(50,40,60,20); add(Labelusernumber); TextFieldusernumber.setBounds(100,40,80,20); add(TextFieldusernumber); Labelpassword.setBounds(50,80,60,20); add(Labelpassword); FieldPassword.setBounds(100,80,80,20); add(FieldPassword); Labelshenfen.setBounds(50,120,60,20); add(Labelshenfen); JC.setBounds(100,120,80,20); add(JC); JC.addItem(new String("老板")); JC.addItem(new String("雇员")); button.setBounds(50,160,60,20); add(button); button.addActionListener(this); setVisible(true); setBounds(0,0,230,200); addWindowListener(new WindowAdapter() { public void windowClosing(WindowEvent e) { System.exit(0); } }); } public static void main(String args[]) { new Login(); } public void actionPerformed(ActionEvent e) { if(e.getSource()==button) { String unum=TextFieldusernumber.getText(); String upassword=FieldPassword.getText(); String box=(String)JC.getSelectedItem(); String sql="select * from employee where Emnum='"+unum+"' and Emkey='"+upassword+"'"; if(box.equals("老板")) { if((unum!=null&&(unum.equals("sada")))&&(upassword!=null&&(upassword.equals("0231")))) { new ShowButton(); //new bossmanage(); } } else if(box.equals("雇员")) { try { Class.forName("sun.jdbc.odbc.JdbcOdbcDriver"); Connection con=DriverManager.getConnection("jdbc:odbc:DBInfo","user","123456"); Statement stm=con.createStatement(); ResultSet rs=stm.executeQuery(sql); if(rs.next()) { new ShowButton(); //new employeemanage(); } } catch(Exception ee) { } } } } }![图片说明](https://img-ask.csdn.net/upload/201511/19/1447946829_228495.png)
Javascript表单验证怎么写
雇员编号,使用数字表示,长度是4位数字 雇员姓名,使用字符串表示,长度是10位字符串 雇员工作 雇佣日期,使用日期形式表示 基本工资,使用小数表示,其中小数位2位,整数位5位 奖金,使用小数表示
ExtJs表格数据不显示,但是数据已经相应到前台
``` var vstore = new Ext.data.JsonStore({ url : 'EmployeeServlet?action=getAll', root : "result", fields : ["id", "name", "password", "email", "bornDate", "intro"] }); vstore.load(); var grid = new Ext.grid.EditorGridPanel({ title : "雇员列表", store : vstore, height : 400, width : 800, columns : [{ header : "ID", dataIndex : "id", sortable : true }, { header : "姓名", dataIndex : "name", editor : new Ext.form.TextField() }, { header : "密码", width : 100, dataIndex : "password" }, { header : "电子邮件", dataIndex : "email", handler : function(v) { return v.link(v); } }, { header : "出生日期", width : 120, dataIndex : "bornDate", sortable : true, editor : new Ext.form.DateField(), renderer : function(v) { return v.format("Y-m-d"); } }, { header : "简介", dataIndex : "intro" }] }); grid.render(Ext.getBody()); ```
Kafka实战(三) - Kafka的自我修养与定位
Apache Kafka是消息引擎系统,也是一个分布式流处理平台(Distributed Streaming Platform) Kafka是LinkedIn公司内部孵化的项目。LinkedIn最开始有强烈的数据强实时处理方面的需求,其内部的诸多子系统要执行多种类型的数据处理与分析,主要包括业务系统和应用程序性能监控,以及用户行为数据处理等。 遇到的主要问题: 数据正确性不足 数据的收集主要...
volatile 与 synchronize 详解
Java支持多个线程同时访问一个对象或者对象的成员变量,由于每个线程可以拥有这个变量的拷贝(虽然对象以及成员变量分配的内存是在共享内存中的,但是每个执行的线程还是可以拥有一份拷贝,这样做的目的是加速程序的执行,这是现代多核处理器的一个显著特性),所以程序在执行过程中,一个线程看到的变量并不一定是最新的。 volatile 关键字volatile可以用来修饰字段(成员变量),就是告知程序任何对该变量...
Java学习的正确打开方式
在博主认为,对于入门级学习java的最佳学习方法莫过于视频+博客+书籍+总结,前三者博主将淋漓尽致地挥毫于这篇博客文章中,至于总结在于个人,实际上越到后面你会发现学习的最好方式就是阅读参考官方文档其次就是国内的书籍,博客次之,这又是一个层次了,这里暂时不提后面再谈。博主将为各位入门java保驾护航,各位只管冲鸭!!!上天是公平的,只要不辜负时间,时间自然不会辜负你。 何谓学习?博主所理解的学习,它是一个过程,是一个不断累积、不断沉淀、不断总结、善于传达自己的个人见解以及乐于分享的过程。
程序员必须掌握的核心算法有哪些?
由于我之前一直强调数据结构以及算法学习的重要性,所以就有一些读者经常问我,数据结构与算法应该要学习到哪个程度呢?,说实话,这个问题我不知道要怎么回答你,主要取决于你想学习到哪些程度,不过针对这个问题,我稍微总结一下我学过的算法知识点,以及我觉得值得学习的算法。这些算法与数据结构的学习大多数是零散的,并没有一本把他们全部覆盖的书籍。下面是我觉得值得学习的一些算法以及数据结构,当然,我也会整理一些看过...
有哪些让程序员受益终生的建议
从业五年多,辗转两个大厂,出过书,创过业,从技术小白成长为基层管理,联合几个业内大牛回答下这个问题,希望能帮到大家,记得帮我点赞哦。 敲黑板!!!读了这篇文章,你将知道如何才能进大厂,如何实现财务自由,如何在工作中游刃有余,这篇文章很长,但绝对是精品,记得帮我点赞哦!!!! 一腔肺腑之言,能看进去多少,就看你自己了!!! 目录: 在校生篇: 为什么要尽量进大厂? 如何选择语言及方...
大学四年自学走来,这些私藏的实用工具/学习网站我贡献出来了
大学四年,看课本是不可能一直看课本的了,对于学习,特别是自学,善于搜索网上的一些资源来辅助,还是非常有必要的,下面我就把这几年私藏的各种资源,网站贡献出来给你们。主要有:电子书搜索、实用工具、在线视频学习网站、非视频学习网站、软件下载、面试/求职必备网站。 注意:文中提到的所有资源,文末我都给你整理好了,你们只管拿去,如果觉得不错,转发、分享就是最大的支持了。 一、电子书搜索 对于大部分程序员...
linux系列之常用运维命令整理笔录
本博客记录工作中需要的linux运维命令,大学时候开始接触linux,会一些基本操作,可是都没有整理起来,加上是做开发,不做运维,有些命令忘记了,所以现在整理成博客,当然vi,文件操作等就不介绍了,慢慢积累一些其它拓展的命令,博客不定时更新 free -m 其中:m表示兆,也可以用g,注意都要小写 Men:表示物理内存统计 total:表示物理内存总数(total=used+free) use...
比特币原理详解
一、什么是比特币 比特币是一种电子货币,是一种基于密码学的货币,在2008年11月1日由中本聪发表比特币白皮书,文中提出了一种去中心化的电子记账系统,我们平时的电子现金是银行来记账,因为银行的背后是国家信用。去中心化电子记账系统是参与者共同记账。比特币可以防止主权危机、信用风险。其好处不多做赘述,这一层面介绍的文章很多,本文主要从更深层的技术原理角度进行介绍。 二、问题引入 假设现有4个人...
GitHub开源史上最大规模中文知识图谱
近日,一直致力于知识图谱研究的 OwnThink 平台在 Github 上开源了史上最大规模 1.4 亿中文知识图谱,其中数据是以(实体、属性、值),(实体、关系、实体)混合的形式组织,数据格式采用 csv 格式。 到目前为止,OwnThink 项目开放了对话机器人、知识图谱、语义理解、自然语言处理工具。知识图谱融合了两千五百多万的实体,拥有亿级别的实体属性关系,机器人采用了基于知识图谱的语义感...
程序员接私活怎样防止做完了不给钱?
首先跟大家说明一点,我们做 IT 类的外包开发,是非标品开发,所以很有可能在开发过程中会有这样那样的需求修改,而这种需求修改很容易造成扯皮,进而影响到费用支付,甚至出现做完了项目收不到钱的情况。 那么,怎么保证自己的薪酬安全呢? 我们在开工前,一定要做好一些证据方面的准备(也就是“讨薪”的理论依据),这其中最重要的就是需求文档和验收标准。一定要让需求方提供这两个文档资料作为开发的基础。之后开发...
网页实现一个简单的音乐播放器(大佬别看。(⊙﹏⊙))
今天闲着无事,就想写点东西。然后听了下歌,就打算写个播放器。 于是乎用h5 audio的加上js简单的播放器完工了。 演示地点演示 html代码如下` music 这个年纪 七月的风 音乐 ` 然后就是css`*{ margin: 0; padding: 0; text-decoration: none; list-...
微信支付崩溃了,但是更让马化腾和张小龙崩溃的竟然是……
loonggg读完需要3分钟速读仅需1分钟事件还得还原到昨天晚上,10 月 29 日晚上 20:09-21:14 之间,微信支付发生故障,全国微信支付交易无法正常进行。然...
Python十大装B语法
Python 是一种代表简单思想的语言,其语法相对简单,很容易上手。不过,如果就此小视 Python 语法的精妙和深邃,那就大错特错了。本文精心筛选了最能展现 Python 语法之精妙的十个知识点,并附上详细的实例代码。如能在实战中融会贯通、灵活使用,必将使代码更为精炼、高效,同时也会极大提升代码B格,使之看上去更老练,读起来更优雅。
数据库优化 - SQL优化
以实际SQL入手,带你一步一步走上SQL优化之路!
2019年11月中国大陆编程语言排行榜
2019年11月2日,我统计了某招聘网站,获得有效程序员招聘数据9万条。针对招聘信息,提取编程语言关键字,并统计如下: 编程语言比例 rank pl_ percentage 1 java 33.62% 2 cpp 16.42% 3 c_sharp 12.82% 4 javascript 12.31% 5 python 7.93% 6 go 7.25% 7 p...
通俗易懂地给女朋友讲:线程池的内部原理
餐盘在灯光的照耀下格外晶莹洁白,女朋友拿起红酒杯轻轻地抿了一小口,对我说:“经常听你说线程池,到底线程池到底是个什么原理?”
《奇巧淫技》系列-python!!每天早上八点自动发送天气预报邮件到QQ邮箱
将代码部署服务器,每日早上定时获取到天气数据,并发送到邮箱。 也可以说是一个小型人工智障。 知识可以运用在不同地方,不一定非是天气预报。
经典算法(5)杨辉三角
杨辉三角 是经典算法,这篇博客对它的算法思想进行了讲解,并有完整的代码实现。
英特尔不为人知的 B 面
从 PC 时代至今,众人只知在 CPU、GPU、XPU、制程、工艺等战场中,英特尔在与同行硬件芯片制造商们的竞争中杀出重围,且在不断的成长进化中,成为全球知名的半导体公司。殊不知,在「刚硬」的背后,英特尔「柔性」的软件早已经做到了全方位的支持与支撑,并持续发挥独特的生态价值,推动产业合作共赢。 而对于这一不知人知的 B 面,很多人将其称之为英特尔隐形的翅膀,虽低调,但是影响力却不容小觑。 那么,在...
腾讯算法面试题:64匹马8个跑道需要多少轮才能选出最快的四匹?
昨天,有网友私信我,说去阿里面试,彻底的被打击到了。问了为什么网上大量使用ThreadLocal的源码都会加上private static?他被难住了,因为他从来都没有考虑过这个问题。无独有偶,今天笔者又发现有网友吐槽了一道腾讯的面试题,我们一起来看看。 腾讯算法面试题:64匹马8个跑道需要多少轮才能选出最快的四匹? 在互联网职场论坛,一名程序员发帖求助到。二面腾讯,其中一个算法题:64匹...
面试官:你连RESTful都不知道我怎么敢要你?
干货,2019 RESTful最贱实践
刷了几千道算法题,这些我私藏的刷题网站都在这里了!
遥想当年,机缘巧合入了 ACM 的坑,周边巨擘林立,从此过上了"天天被虐似死狗"的生活… 然而我是谁,我可是死狗中的战斗鸡,智力不够那刷题来凑,开始了夜以继日哼哧哼哧刷题的日子,从此"读题与提交齐飞, AC 与 WA 一色 ",我惊喜的发现被题虐既刺激又有快感,那一刻我泪流满面。这么好的事儿作为一个正直的人绝不能自己独享,经过激烈的颅内斗争,我决定把我私藏的十几个 T 的,阿不,十几个刷题网...
为啥国人偏爱Mybatis,而老外喜欢Hibernate/JPA呢?
关于SQL和ORM的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行了一番讨论,感触还是有一些,于是就有了今天这篇文。 声明:本文不会下关于Mybatis和JPA两个持久层框架哪个更好这样的结论。只是摆事实,讲道理,所以,请各位看官勿喷。 一、事件起因 关于Mybatis和JPA孰优孰劣的问题,争论已经很多年了。一直也没有结论,毕竟每个人的喜好和习惯是大不相同的。我也看...
白话阿里巴巴Java开发手册高级篇
不久前,阿里巴巴发布了《阿里巴巴Java开发手册》,总结了阿里巴巴内部实际项目开发过程中开发人员应该遵守的研发流程规范,这些流程规范在一定程度上能够保证最终的项目交付质量,通过在时间中总结模式,并推广给广大开发人员,来避免研发人员在实践中容易犯的错误,确保最终在大规模协作的项目中达成既定目标。 无独有偶,笔者去年在公司里负责升级和制定研发流程、设计模板、设计标准、代码标准等规范,并在实际工作中进行...
SQL-小白最佳入门sql查询一
不要偷偷的查询我的个人资料,即使你再喜欢我,也不要这样,真的不好;
项目中的if else太多了,该怎么重构?
介绍 最近跟着公司的大佬开发了一款IM系统,类似QQ和微信哈,就是聊天软件。我们有一部分业务逻辑是这样的 if (msgType = "文本") { // dosomething } else if(msgType = "图片") { // doshomething } else if(msgType = "视频") { // doshomething } else { // doshom...
Nginx 原理和架构
Nginx 是一个免费的,开源的,高性能的 HTTP 服务器和反向代理,以及 IMAP / POP3 代理服务器。Nginx 以其高性能,稳定性,丰富的功能,简单的配置和低资源消耗而闻名。 Nginx 的整体架构 Nginx 里有一个 master 进程和多个 worker 进程。master 进程并不处理网络请求,主要负责调度工作进程:加载配置、启动工作进程及非停升级。worker 进程负责处...
YouTube排名第一的励志英文演讲《Dream(梦想)》
Idon’t know what that dream is that you have, I don't care how disappointing it might have been as you've been working toward that dream,but that dream that you’re holding in your mind, that it’s po...
“狗屁不通文章生成器”登顶GitHub热榜,分分钟写出万字形式主义大作
一、垃圾文字生成器介绍 最近在浏览GitHub的时候,发现了这样一个骨骼清奇的雷人项目,而且热度还特别高。 项目中文名:狗屁不通文章生成器 项目英文名:BullshitGenerator 根据作者的介绍,他是偶尔需要一些中文文字用于GUI开发时测试文本渲染,因此开发了这个废话生成器。但由于生成的废话实在是太过富于哲理,所以最近已经被小伙伴们给玩坏了。 他的文风可能是这样的: 你发现,...
程序员:我终于知道post和get的区别
是一个老生常谈的话题,然而随着不断的学习,对于以前的认识有很多误区,所以还是需要不断地总结的,学而时习之,不亦说乎
相关热词 c# clr dll c# 如何orm c# 固定大小的字符数组 c#框架设计 c# 删除数据库 c# 中文文字 图片转 c# 成员属性 接口 c#如何将程序封装 16进制负数转换 c# c#练手项目
立即提问