When you give a list of equations to Solve, it assumes that you want all the equations to be satisfied simultaneously. It is also possible to give Solve more complicated logical combinations of equations.
Solve assumes that the equations x+y==1 and x-y==2 are simultaneously valid:
Here is an alternative form, using the logical connective && explicitly:
This specifies that eitherx+y==1orx-y==2. Solve gives two solutions for x, corresponding to these two possibilities:
If you explicitly include the assertion that x!=0, one of the previous solutions is suppressed:
Here is a slightly more complicated example. Note that the precedence of || is lower than the precedence of &&, so the equation is interpreted as (x^3==x&&x!=1)||x^2==2, not x^3==x&&(x!=1||x^2==2):
When you use Solve, the final results you get are in the form of transformation rules. If you use Reduce or Eliminate, on the other hand, then your results are logical statements, which you can manipulate further.
This gives a logical statement representing the solutions of the equation x^2==x:
This finds values of x which satisfy x^5==x but do not satisfy the statement representing the solutions of x^2==x:
The logical statements produced by Reduce can be thought of as representations of the solution set for your equations. The logical connectives &&, || and so on then correspond to operations on these sets.